Paweł Bugalski created LUCENE-9791: --------------------------------------
Summary: Monitor (aka Luwak) has concurrency issues related to BytesRefHash#find Key: LUCENE-9791 URL: https://issues.apache.org/jira/browse/LUCENE-9791 Project: Lucene - Core Issue Type: Bug Components: core/other Affects Versions: 8.8, 8.7, master (9.0) Reporter: Paweł Bugalski _org.apache.lucene.monitor.Monitor_ can sometimes *NOT* match a document that should be matched by one of registered queries if match operations are run concurrently from multiple threads. This is because sometimes in a concurrent environment _TermFilteredPresearcher_ might not select a query that could later on match one of documents being matched. Internally _TermFilteredPresearcher_ is using a term acceptor: an instance of _org.apache.lucene.monitor.QueryIndex.QueryTermFilter_. _QueryTermFilter_ is correctly initialized under lock and its internal state (a map of _org.apache.lucene.util.BytesRefHash_ instances) is correctly published. Later one when those instances are used concurrently a problem with _org.apache.lucene.util.BytesRefHash#find_ is triggered since it is not thread safe. _org.apache.lucene.util.BytesRefHash#find_ internally is using a private _org.apache.lucene.util.BytesRefHash#equals_ method, which is using an instance field _scratch1_ as a temporary buffer to compare its _ByteRef_ parameter with contents of _ByteBlockPool_. This is not thread safe and can cause incorrect answers as well as _ArrayOutOfBoundException_. __ -- This message was sent by Atlassian Jira (v8.3.4#803005) --------------------------------------------------------------------- To unsubscribe, e-mail: issues-unsubscr...@lucene.apache.org For additional commands, e-mail: issues-h...@lucene.apache.org