Skip to Main Content

MongoByte MongoDB Logo

Welcome to the new MongoDB Feedback Portal!

{Improvement: "Your idea"}
We’ve upgraded our system to better capture and act on your feedback.
Your feedback is meaningful and helps us build better products.

Status Submitted
Categories Atlas Search
Created by Guest
Created on Jun 4, 2024

Atlas Search Local Deployment Lucene Indexing Latency of 1s

We are unit testing our Java application using the (awesome!) Atlas Search Local Deployments. However, we are seeing a longer delay than we'd like between the time we add data to a collection and the time it is searchable in the Atlas Search Lucene index. It is almost always uniformly 1 second. Here's a unit test that demonstrates the issue: https://github.com/luketn/atlas-search-unit-test-latency-issue/blob/main/src/test/java/com/mycodefu/MainTest.java#L95 This should take a few milliseconds to run, but it will take almost exactly a minute. Each iteration of the loop in the test will take almost exactly 1s. The first iteration will usually be shorter, because we start somewhere in the middle of the 1s refresh period: > Time taken for search query to find document: 556ms Example output of iterations: > Time taken for search query to find document: 1009ms > Time taken for search query to find document: 989ms > Time taken for search query to find document: 1018ms Output at the end: > Time taken for test to run: 60s It may be sensible in production use cases for the eventual consistency of Atlas Search to be 1s. However during unit testing this presents a real problem. I'm not sure what the best solution would be, but perhaps the indexes could be made available in a more realtime fashion (particularly for unit testing). A couple of ideas for a solution: - allow a write concern by connection or insert/update which triggers immediate refresh of the Atlas Search indexes so that you could selectively - instead of using a periodic refresh on a 1s basis, update the queryable indexes in real time as changes are written (not sure if there are tradeoffs) - support a command which can be used to trigger an update on Atlas Search indexes
  • Guest
    Mar 19, 2025
    Hello and thank you for the feedback, We appreciate you taking the time to thoroughly document and share your testing scenario with us. We're actively considering your need for more responsive indexing in test environments within our product roadmap. As we expand search capabilities to our open source offering, exposing more fine-grained control of indexes (such as configurable index refresh times, or manual refresh triggers) is something we will actively investigate. In the meantime, we recommend implementing a delay/polling mechanism in your tests. While we recognize its not ideal, this is a common testing technique when working with eventually consistent systems. As you've noted, the indexing will never be truly instantaneous - even with improvements, there will always be some processing time greater than zero. Your suggestions align well with our thinking about how to improve the developer experience, particularly in testing scenarios. This is an area of the product that is fairly new to market, and a use case that is picking up adoption, and thus we have not received much feedback to inspire the need for these features. I will set the expectation that the local development version of search will soon adopt a different version of the search binary that we release for MongoDB Community later this year. When this happens, we will have more freedom to consider extended configurability. That being said, we do not expect the current behavior to change in the near term. Thanks again for your contribution to making our product better. -The Atlas Search Product Team