加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

修改solrconfig.xml文件

发布时间:2020-12-16 05:59:49 所属栏目:百科 来源:网络整理
导读:有时候我们的查询条件会非常多,由于solr的booleanquery默认设置的条件数为1024,所以超过这个限制的 会报异常,这样设置的原因是为了限制过多条件查询,降低查询的性能,但有时候又必须这样查,或分析数据用, 所以可以临时改变下,修改方法: 修改solrconf

有时候我们的查询条件会非常多,由于solr的booleanquery默认设置的条件数为1024,所以超过这个限制的
会报异常,这样设置的原因是为了限制过多条件查询,降低查询的性能,但有时候又必须这样查,或分析数据用,
所以可以临时改变下,修改方法:

修改solrconfig.xml文件:

Java代码
  1. <maxBooleanClauses>20000</maxBooleanClauses>
 <maxBooleanClauses>20000</maxBooleanClauses>



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

Java代码
  1. toomanybooleanclausesException
too many boolean clauses Exception



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

Java代码
  1. MaxBooleanClauses
  2. MaximumnumberofclausesineachBooleanQuery,anexception
  3. isthrownifexceeded.
  4. **WARNING**
  5. ThisoptionactuallymodifiesaglobalLucenepropertythat
  6. willaffectallSolrCores.Ifmultiplesolrconfig.xmlfiles
  7. disagreeonthisproperty,thevalueatanygivenmomentwill
  8. bebasedonthelastSolrCoretobeinitialized.
 
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代码
  1. //过滤的几种写法
  2. 1)q=category:1ANDcategory:2ANDcategory:3...ANDcategory:2000
  3. 2)q=*:*&fq=category:(123...2000)
  4. 3)q=*:*&fq=category:1&fq=category:2&fq=category:3&....&fq=category:2000
 //过滤的几种写法
  (1)q=category:1 AND category:2 AND category:3 ... AND category:2000
 (2)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方法,而不用配置最大限制条件

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读