Search code examples
azureazure-cognitive-searcheventual-consistency

Azure Search | Total ordering of index updates


I've read through this excellent feedback on Azure Search. However, I have to be a bit more explicit in questioning one the answers to question #1 from that list...

...When you index data, it is not available for querying immediately.

...Currently there is no mechanism to control concurrent updates to the same document in an index.

Eventual consistency is fine - I perform a few updates and eventually I will see my updates on read/query.

However, no guarantee on ordering of updates is really problematic. Perhaps I'm misunderstanding Let's assume this basic scenario:

1) update index entry E.fieldX w/ foo at time 12:00:01
2) update index entry E.fieldX w/ bar at time 12:00:02

From what I gather, it's entirely possible that E.fieldX will contain "foo" after all updates have been processed?

If that is true, it seems to severely limit the applicability of this product.


Solution

  • Currently, Azure Search does not provide document-level optimistic concurrency, primarily because overwhelming majority of scenarios don't require it. Please vote for External Version UserVoice suggestion to help us prioritize this ask.

    One way to manage data ingress concurrency today is to use Azure Search indexers. Indexers guarantee that they will process only the current version of a source document at each point of time, removing potential for races.