Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Solr配置maxBooleanClauses属性不生效原因分析

Solr配置maxBooleanClauses属性不生效原因分析

作者头像
我是攻城师
发布于 2018-05-14 06:10:02
发布于 2018-05-14 06:10:02
1.3K00
代码可运行
举报
文章被收录于专栏:我是攻城师我是攻城师
运行总次数:0
代码可运行

上次已经写过一篇关于solr中,查询条件过多的异常的文章,这次在总结扩展一下: 有时候我们的查询条件会非常多,由于solr的booleanquery默认设置的条件数为1024,所以超过这个限制的 会报异常,这样设置的原因是为了限制过多条件查询,降低查询的性能,但有时候又必须这样查,或分析数据用, 所以可以临时改变下,修改方法: 修改solrconfig.xml文件:

Java代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<maxBooleanClauses>20000</maxBooleanClauses>  

理想情况下,配置完这个属性,重启应该就生效了,但是让你意外的是,并没有生效,拼接5000个查询条件,依然报这个异常:

Java代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
too many boolean clauses Exception  

为什么? 仔细看solr的文档里面,写这下面一段话:

Java代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 
Max Boolean Clauses  
 
         Maximum number of clauses in each BooleanQuery,  an exception  
         is thrown if exceeded.  
 
         ** WARNING **  
 
         This option actually modifies a global Lucene property that  
         will affect all SolrCores.  If multiple solrconfig.xml files  
         disagree on this property, the value at any given moment will  
         be based on the last SolrCore to be initialized.  

什么意思?大致就是说,这个属性是全局的lucene配置,如果你的solr里面存在多个core,那么必须多个core的配置 文件都得配置maxBooleanClauses才会生效,否则只有当你配置的那个core最后一个被加载时,它才会生效,如果不幸,不是最后一个加载,那么即使你设置成20000那么它默认还是1024,这就是为什么配置完成之后依旧不生效的原因,散仙的场景中,参数大概有8000多个,虽然改变配置可以查询,但不建议这么用,内存不给力的情况下,查询速度非常之慢,用于离线分析某些数据,倒还可以接受。 最后在补充一些查询知识:

Java代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
//过滤的几种写法 1)q=category:1 AND category:2 AND category:3 ... AND category:20002)q=*:*&fq=category:(1 2 3 ... 2000)3)q=*:*&fq=category:1&fq=category:2&fq=category:3&....&fq=category:2000 

总结: (1)如果是or操作多个条件,只能配置最大限制条件 (2)如果是and操作多个条件,可以上面的3方法,而不用配置最大限制条件 参考文章:http://solr.pl/en/2011/12/19/do-i-have-to-look-for-maxbooleanclauses-when-using-filters/

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2015-12-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 我是攻城师 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
day66_Solr学习笔记
目录结构详解如下:   bin:solr的运行脚本。   contrib:solr的一些扩展jar包,用于增强solr的功能。   dist:该目录包含build过程中产生的war和jar文件,以及相关的依赖文件。   docs:solr的API文档。   example:solr工程的例子目录: example/solr:      该目录是一个标准的SolrHome目录,它包含一个默认的SolrCore目录collection1。 SolrHome目录:
黑泽君
2018/12/05
1.3K0
day66_Solr学习笔记
Web-第二十八天 Lucene&solr使用一【悟空教程】
上图就是原始搜索引擎技术,如果用户比较少而且数据库的数据量比较小,那么这种方式实现搜索功能在企业中是比较常见的。
Java帮帮
2018/08/06
1.4K0
Web-第二十八天 Lucene&solr使用一【悟空教程】
Solr集成Tomcat
Solr是一个独立的企业级搜索应用服务器,它对外提供类似于Web-service的API接口。用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引;也可以通过Http Get操作提出查找请求,并得到XML格式的返回结果。
全栈程序员站长
2022/06/29
1.3K0
Solr集成Tomcat
solr install
     Solr是一个独立的企业及搜索应用服务器,它对外提供类似于Web-service的API接口。用户可以通过http请求,向搜索引擎服务器提交一定格式的XML文件,生成索引;也可以通过Http Get操作提出查找请求,并得到XML格式的返回结果。solr可以运行在Jetty、Tomcat等服务器上面。
week
2018/08/24
9630
solr install
Solr 8.2 使用指南
Solr是一个基于全文检索的企业级应用服务器。可以输入一段文字,通过分词检索数据。它是单独的服务,部署在 tomcat。
Carlos Ouyang
2019/08/19
3.1K1
Solr 8.2 使用指南
【详解】CentOS安装与配置Solr6.5
Apache Solr 是一个高性能的全文搜索服务器,支持高级的全文搜索、结构化/非结构化数据搜索、实时索引、动态聚类、数据库集成和丰富的文档处理等功能。本文将详细介绍在CentOS系统上安装和配置Solr 6.5的步骤。
大盘鸡拌面
2025/01/28
1470
Lucene&Solr框架之第二篇
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
海仔
2019/10/22
1.7K0
solr基本概念
其实简单的说,Solr是一个基于Apache Lucene 项目的开源企业级搜索平台,是用JAVA编写的、运行在Servlet容器中的一个独立的全文搜索服务器(换句话说就是个JAVA-WEB APP),并具有类似REST的HTTP/XML和JSON的API。
create17
2019/03/15
1.6K0
solr基本概念
Solr的基本使用
schema.xml,在SolrCore的conf目录下,它是Solr数据表配置文件,它定义了加入索引的数据的数据类型的。主要包括FieldTypes、Fields和其他的一些缺省设置。
良月柒
2019/03/19
1.9K0
(三)solr的dataimport的配置以及中文分词
并可以在apache-tomcat-7.0.73\webapps\solr\WEB-INF\classes下新建自己的扩展词典
qubianzhong
2018/09/19
1.2K0
(三)solr的dataimport的配置以及中文分词
第4章 配置Solr
到目前为止,你已经提出了什么信仰,没有学习Solr是如何工作的。我们会改变,在这一章和下一个通过学习如何配置和配置设置如何影响Solr的行为。您将看到,Solr的配置可以在第一次看到令人生畏的,因为示例的配置文件在Solr服务器包含几乎所有可能的配置设置。我们在这一章的重点介绍最重要的配置设置Solr,尤其是那些影响Solr如何处理来自客户机应用程序的请求。你获得的知识在本章将被应用在这本书的其余部分。阅读本章后,你将有一个公司的理解如何在Solr服务器上执行查询。
幽鸿
2020/04/02
6830
Apache Solr CVE-2019-17558漏洞复现
Apache Solr是一个企业级搜索平台,用Java编写且开源,基于Apache Lucene项目。
sugarbeet
2022/09/26
1.1K0
Apache Solr CVE-2019-17558漏洞复现
solr使用教程二【面试+工作】
6.3高亮显示 我们经常使用搜索引擎,比如在baidu 搜索 java ,会出现如下结果,结果中与关键字匹配的地方是红色显示与其他内容区别开来。 solr 默认已经配置了highlight 组件(详见
Java帮帮
2018/04/17
1.4K0
solr使用教程二【面试+工作】
Solr单机版的安装与使用
1 1、使用Solr实现。 2 基于Solr实现站内搜索扩展性较好并且可以减少程序员的工作量,因为Solr提供了较为完备的搜索引擎解决方案,因此在门户、论坛等系统中常用此方案。 3 4 2、什么是Solr。 5 Solr是Apache下的一个顶级开源项目,采用Java开发,它是基于Lucene的全文搜索服务器。Solr提供了比Lucene更为丰富的查询语言,同时实现了可配置、可扩展,并对索引、 6 搜索性能进行了优化。 7 Solr可以独立运行,运行在Jetty、Tomcat等这些Servlet容器中,Solr索引的实现方法很简单,用 POST 方法向 Solr 服务器发送一个描述 Field 及其内容的 XML 文档, 8 Solr根据xml文档添加、删除、更新索引 。Solr搜索只需要发送 HTTP GET 请求,然后对 Solr返回Xml、json等格式的查询结果进行解析,组织页面布局。 9 Solr不提供构建UI的功能,Solr提供了一个管理界面,通过管理界面可以查询Solr的配置和运行情况。 10 11 3、Solr与Lucene的区别。 12 Lucene是一个开放源代码的全文检索引擎工具包,它不是一个完整的全文检索引擎,Lucene提供了完整的查询引擎和索引引擎,目的是为软件开发人员提供一个简单易用的 13 工具包,以方便的在目标系统中实现全文检索的功能,或者以Lucene为基础构建全文检索引擎。 14 Solr的目标是打造一款企业级的搜索引擎系统,它是一个搜索引擎服务,可以独立运行,通过Solr可以非常快速的构建企业的搜索引擎,通过Solr也可以高效的完成站内搜 15 索功能。
别先生
2019/09/29
1.4K0
Solr单机版的安装与使用
Apache Solr查询语法
表示:查询category=2002、en_US_city_i=110以及namespace=d的前六条记录,只返回productId和category字段
九州暮云
2019/08/21
1.3K0
Solr的知识点学习 Solr单机版的安装与使用
1、Solr单机版的安装与使用,简单写了如何进行Solr的安装与使用。那么很多细节性问题,这里进行简单的介绍。我使用的是Solr与Tomcat整合配置。
别先生
2019/09/29
1.2K0
Solr的知识点学习

            Solr单机版的安装与使用
Solr搜索引擎 — 通过mysql配置数据源
上一节我们已经通过两种方式运行了solr,本节演示怎么配置solr的mysql数据源
喵了个咪233
2019/05/26
1.6K0
Solr基本搭建及MySQL配置
启动后访问 http://127.0.0.1:8983/, 理论上即可进入Solr管理界面。具体内容见Solr Admin UI
lpe234
2020/07/27
1.1K0
分布式--solr搜索引擎
搜索是项目中常用的功能,对于大数据量的搜索,查询关系型数据库是非常低效的,好在有三方专门用于搜索的工具,常用的搜索解决方案为:
aruba
2022/09/08
8070
分布式--solr搜索引擎
solr使用教程【面试+工作】
solr使用教程一【面试+工作】 Solr调研总结 开发类型全文检索相关开发 Solr版本4.2文件内容本文介绍solr的功能使用及相关注意事项;主要包括以下内容:环境搭建及调试;两个核心配置文件介绍;维护索引;查询索引,和在查询中可以应用的高亮显示、拼写检查、搜索建议、分组统计、拼音检索等功能的使用方法。版本作者/修改人日期V1.0gzk2013-06-04 1. Solr 是什么? Solr它是一种开放源码的、基于 Lucene Java 的搜索服务器,易于加入到 Web 应用程序中。Solr 提
Java帮帮
2018/04/17
8.5K0
solr使用教程【面试+工作】
相关推荐
day66_Solr学习笔记
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验