Join us Sept 17 at .local NYC! Use code WEB50 to save 50% on tickets. Learn more >
MongoDB Jokes
Docs Menu
Docs Home
/ /

Parallelize Query Execution Across Segments

The concurrent option enables intra-query parallelism. In this mode, MongoDB Search utilizes more resources, but improves each individual query latency. This feature is only available for dedicated Search Nodes.

When you run queries with the concurrent option, MongoDB Search doesn't guarantee that each query will be executed concurrently. For example, when too many concurrent queries are queued, MongoDB Search might fallback to single-threaded execution.

concurrent has the following syntax:

{
"$searchMeta"|"$search": {
"index": "<index name>", // optional, defaults to "default"
"<operator>": {
<operator-specifications>
},
"concurrent": true | false,
...
}
}

The concurrent boolean option allows you to request MongoDB Search to parallelize query execution across segments, which, in many cases, improves the response time. You can set one of the following values for the concurrent option:

  • true - to request MongoDB Search to run the query multi-threaded

  • false - to run the query single-threaded (default)

MongoDB Search provides you control over this behavior on a per-query basis to enable concurrent execution only for heavy and long-running queries, which minimizes the contention and improves overall query throughput. Concurrent execution is especially efficient on large datasets, as there is a larger amount of segments.

Consider the following query against the sample_mflix.movies collection in the sample data. The query indicates a concurrent search for movies that contain the term new york in the title.

1db.movies.aggregate([
2 {
3 "$search": {
4 "text": {
5 "path": "title",
6 "query": "new york"
7 },
8 "concurrent": true
9 }
10 }
11])

Back

Performance Options

On this page