Solr学习总结-改进Solr性能

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>
改进facet性能,查询的时候指定缓存

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

你可能感兴趣的:(Solr,存储,Class,文档,import,facet)