Mikhail Khludnev created SOLR-7730:
--------------------------------------

             Summary: don't merge FieldInfos on 
SlowCompositeReaderWrapper.getSortedSetDocValues() getSortedDocValues()
                 Key: SOLR-7730
                 URL: https://issues.apache.org/jira/browse/SOLR-7730
             Project: Solr
          Issue Type: Improvement
          Components: faceting
            Reporter: Mikhail Khludnev


every time we count facets on DocValues fields in Solr on many segments index 
we see the unnecessary hotspot:
{code}
....
        at 
org.apache.lucene.index.MultiFields.getMergedFieldInfos(MultiFields.java:248)
        at 
org.apache.lucene.index.SlowCompositeReaderWrapper.getFieldInfos(SlowCompositeReaderWrapper.java:239)
        at 
org.apache.lucene.index.SlowCompositeReaderWrapper.getSortedSetDocValues(SlowCompositeReaderWrapper.java:176)
        at 
org.apache.solr.request.DocValuesFacets.getCounts(DocValuesFacets.java:72)
        at 
org.apache.solr.request.SimpleFacets.getTermCounts(SimpleFacets.java:460) ....
{code}

the reason is 
[SCWR.getSortedSetDocValues()|https://github.com/apache/lucene-solr/blob/trunk/lucene/core/src/java/org/apache/lucene/index/SlowCompositeReaderWrapper.java#L136]
 and 
[SCWR.getSortedDocValues()|https://github.com/apache/lucene-solr/blob/trunk/lucene/core/src/java/org/apache/lucene/index/SlowCompositeReaderWrapper.java#L174]

before return composite doc values, SCWR merges segment field infos, which is 
expensive, but after fieldinfo is merged, it checks *only* docvalue type in it. 
This dv type check can be done much easier in per segment basis. 

This patch gets some performance gain for those who count DV facets in Solr.




--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to