queryResultWindowSize:一次查询中存储最多的doc的id数目。
queryResultMaxDocsCached:一次查询中存储最多的doc数目
<documentCache
class="solr.LRUCache"
size="2560"
initialSize="2560"/>:doc缓存的大小,即存储的doc的数量。大小要大于一次查询的结果集数量乘以并发查询数量。
<queryResultCache
class="solr.LRUCache"
size="16000"
initialSize="8000"
autowarmCount="4000"/>:缓存最多的doc的id集合。大小为查询的数量乘以域的数量再乘以可以排序的域的数量。
<filterCache
class="solr.FastLRUCache"
size="2000"
initialSize="1000"
autowarmCount="1000"/>:查询时有q也有fq,fq求交再与q求并。filterCache缓存key为查询语句和,value为文档id。主要用在facet。
预热查询,在solr启动后放入缓存:
- <listener event="firstSearcher" class="solr.QuerySenderListener">
- <arr name="queries">
- <lst><str name="q">cats</str><str name="fq">category:1</
- str><str name="sort">title desc,value desc,score desc</str><str
- name="start">0</str><str name="rows">20</str></lst>
- <lst><str name="q">cars</str><str name="fq">category:2</
- str><str name="sort">title desc</str><str name="start">0</str><str
- name="rows">20</str></lst>
- <lst><str name="q">harry</str><str name="fq">category:4</
- str><str name="sort">score desc</str><str name="start">0</str><str
- name="rows">20</str></lst>
- </arr>
- </listener>
- <listener event="newSearcher" class="solr.QuerySenderListener">
- <arr name="queries">
- <lst><str name="q">cats</str><str name="fq">category:1</
- str><str name="sort">title desc,value desc,score desc</str><str
- name="start">0</str><str name="rows">20</str></lst>
- <lst><str name="q">cars</str><str name="fq">category:2</
- str><str name="sort">title desc</str><str name="start">0</str><str
- name="rows">20</str></lst>
- <lst><str name="q">harry</str><str name="fq">category:4</
- str><str name="sort">score desc</str><str name="start">0</str><str name="rows">20</str></lst>
- </arr>
- </listener>
指定多个片:http://localhost:8983/solr/select/?q=*:*&shards=localhost:8983/solr,localhost:8984/solr
缓存查询结果页面,相同的查询输入在一小时内会直接返回而不进行查询:
- <requestDispatcher handleSelect="true">
- <httpCaching lastModifiedFrom="openTime" etagSeed="Solr">
- <cacheControl>max-age=3600, public</cacheControl>
- </httpCaching>
- </requestDispatcher>
http://localhost:8983/solr/select/?q=company&facet=true&facet.field=facetCity&facet.field=facetState&f.facetCity.facet.method=enum&f.facetState.facet.method=enum
Data Import Handler加快建立索引,1分钟提交一次和50000个文档提交一次:
- <updateHandler class="solr.DirectUpdateHandler2">
- <autoCommit>
- <maxTime>60000</maxTime>
- </autoCommit>
- </updateHandler>
- <updateHandler class="solr.DirectUpdateHandler2">
- <autoCommit>
- <maxDocs>50000</maxDocs>
- </autoCommit>
- </updateHandler>
尽快返回一定数目的文档,100毫秒要求返回:
http://localhost:8983/solr/select?q=financial report&timeAllowed=100
多长时间提交一次:
<autoCommit>
<maxTime>${solr.autoCommit.maxTime:15000}</maxTime>
<openSearcher>false</openSearcher>
</autoCommit>
查询条件的大小:(超过会报错)
<maxBooleanClauses>3024</maxBooleanClauses>
限制返回值的大小:
- <!-- Request Parsing:请求解析
- 这些设置说明Solr Requests如何被解析,以及对ContentStreams有什么限制。
- enableRemoteStreaming - 是否允许使用stream.file和stream.url参数来指定远程streams。
- multipartUploadLimitInKB - 指定多文件上传时Solr允许的最大的size。
- formdataUploadLimitInKB - 表单通过POST请求发送的最大size
- -->
- <requestParsers enableRemoteStreaming="true"
- multipartUploadLimitInKB="2048000"
- formdataUploadLimitInKB="2048"/>