MongoDB Atlas and Vector Search
MongoDB Atlas is a fully-managed cloud database available in AWS, Azure, and GCP. It supports native Vector Search and full text search (BM25) on your MongoDB document data.
MongoDB Atlas Vector Search allows you to store your embeddings in MongoDB documents, create vector search indexes, and perform KNN search with an approximate nearest neighbor algorithm called Hierarchical Navigable Small Worlds. You can implement this feature by using the $vectorSearch
MQL aggregation stage.
Prerequisites
Vector Search requires the following or later MongoDB versions:
- 6.0.11
- 7.0.2
Vector Search is available on Atlas, and as of 2024 is available in early access for Community Edition.
MongoDB offers a free forever cluster. See the Get Started with Atlas tutorial to learn more. Once you deploy a cluster, you can create a vector search index by using the index JSON editor. Alternatively, the LangChain4j MongoDbEmbeddingStore
builder offers a createIndex
option to automate index creation.
MongoDB also offers Atlas CLI for local development.
Maven Dependency
<dependency>
<groupId>dev.langchain4j</groupId>
<artifactId>langchain4j-mongodb-atlas</artifactId>
<version>0.36.2</version>
</dependency>
APIs
MongoDbEmbeddingStore