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

Get Started with the Amazon Bedrock Knowledge Base Integration

Note

Atlas is currently available as a knowledge base in AWS regions located in the United States only.

You can use MongoDB Atlas as a knowledge base for Amazon Bedrock to build generative AI applications, implement retrieval-augmented generation (RAG), and build agents.

The Amazon Bedrock Knowledge Base integration with Atlas enables the following use cases:

  • Use foundation models with MongoDB Vector Search to build AI applications and implement RAG. To get started, see Get Started.

  • Enable hybrid search with MongoDB Vector Search and MongoDB Search for your knowledge base. To learn more, see Hybrid Search with Amazon Bedrock and Atlas.

This tutorial demonstrates how to start using MongoDB Vector Search with Amazon Bedrock. Specifically, you perform the following actions:

  1. Load custom data into an Amazon S3 bucket.

  2. Optionally, configure an endpoint service using AWS PrivateLink.

  3. Create a MongoDB Vector Search index on your data.

  4. Create a knowledge base to store data on Atlas.

  5. Create an agent that uses MongoDB Vector Search to implement RAG.

Amazon Bedrock is a fully-managed service for building generative AI applications. It allows you to leverage foundation models (FMs) from various AI companies as a single API.

You can use MongoDB Vector Search as a knowledge base for Amazon Bedrock to store custom data in Atlas and create an agent to implement RAG and answer questions on your data. To learn more about RAG, see Retrieval-Augmented Generation (RAG) with MongoDB.

To complete this tutorial, you must have the following:

If you don't already have an Amazon S3 bucket that contains text data, create a new bucket and load the following publicly accessible PDF about MongoDB best practices:

1
  1. Navigate to the Best Practices Guide for MongoDB.

  2. Click either Read Whitepaper or Email me the PDF to access the PDF.

  3. Download and save the PDF locally.

2
  1. Follow the steps to create an S3 Bucket. Ensure that you use a descriptive Bucket Name.

  2. Follow the steps to upload a file to your Bucket. Select the file that contains the PDF that you just downloaded.

By default, Amazon Bedrock connects to your knowledge base over the public internet. To further secure your connection, MongoDB Vector Search supports connecting to your knowledge base over a virtual network through an AWS PrivateLink endpoint service.

Optionally, complete the following steps to enable an endpoint service that connects to an AWS PrivateLink private endpoint for your Atlas cluster:

1

Follow the steps to set up a AWS PrivateLink private endpoint for your Atlas cluster. Ensure that you use a descriptive VPC ID to identify your private endpoint.

For more information, see Learn About Private Endpoints in Atlas.

2

MongoDB and partners provide a Cloud Development Kit (CDK) that you can use to configure an endpoint service backed by a network load balancer that forwards traffic to your private endpoint.

Follow the steps specified in the CDK GitHub Repository to prepare and run the CDK script.

In this section, you set up Atlas as a vector database, also called a vector store, by creating a MongoDB Vector Search index on your collection.

To create a MongoDB Vector Search index, you must have Project Data Access Admin or higher access to the Atlas project.

1

WARNING: Navigation Improvements In Progress We're currently rolling out a new and improved navigation experience. If the following steps don't match your view in the Atlas UI, see the preview documentation.

  1. If it's not already displayed, select the organization that contains your desired project from the Organizations menu in the navigation bar.

  2. If it's not already displayed, select your desired project from the Projects menu in the navigation bar.

  3. If it's not already displayed, click Clusters in the sidebar.

    The Clusters page displays.

2

Click the Browse Collections button for your cluster.

The Data Explorer displays.

3
  1. Click the + Create Database button.

  2. For the Database name enter bedrock_db.

  3. For the Collection name, enter test.

  4. Click Create to create the database and its first collection.

4

You can go the MongoDB Search page from the sidebar, the Data Explorer, or your cluster details page.

  1. In the sidebar, click Atlas Search under the Services heading.

    If you have no clusters, click Create cluster to create one. To learn more, see Create a Cluster.

  2. If your project has multiple clusters, select the cluster you want to use from the Select cluster dropdown, then click Go to Atlas Search.

    The Atlas Search page displays.

  1. Click the Browse Collections button for your cluster.

  2. Expand the database and select the collection.

  3. Click the Search Indexes tab for the collection.

    The Atlas Search page displays.

  1. Click the cluster's name.

  2. Click the Atlas Search tab.

    The Atlas Search page displays.

5
6

Make the following selections on the page and then click Next.

Search Type

Select the Vector Search index type.

Index Name and Data Source

Specify the following information:

  • Index Name: vector_index

  • Database and Collection:

    • bedrock_db database

    • test collection

Configuration Method

For a guided experience, select Visual Editor.

To edit the raw index definition, select JSON Editor.

IMPORTANT: .. include:: /includes/fts/facts/fact-default-index-name.rst

7

This vectorSearch type index definition indexes the following fields:

  • embedding field as the vector type. The embedding field contains the vector embeddings created using the embedding model that you specify when you configure the knowledge base. The index definition specifies 1024 vector dimensions and measures similarity using cosine.

  • bedrock_metadata, bedrock_text_chunk, and x-amz-bedrock-kb-document-page-number fields as the filter type for pre-filtering your data. You will also specify these fields in Amazon Bedrock when you configure the knowledge base.

Note

If you previously created an index with the filter field page_number, you must update your index definition to use the new filter field name x-amz-bedrock-kb-document-page-number instead. Amazon Bedrock has updated the field name, and indexes using the old field name no longer work correctly with Amazon Bedrock knowledge bases.

Specify embedding as the field to index and specify 1024 dimensions.

To configure the index, do the following:

  1. Select Cosine from the Similarity Method dropdown.

  2. In the Filter Field section, specify the bedrock_metadata, bedrock_text_chunk, and x-amz-bedrock-kb-document-page-number fields to filter the data by.

Paste the following index definition in the JSON editor:

1{
2 "fields": [
3 {
4 "numDimensions": 1024,
5 "path": "embedding",
6 "similarity": "cosine",
7 "type": "vector"
8 },
9 {
10 "path": "bedrock_metadata",
11 "type": "filter"
12 },
13 {
14 "path": "bedrock_text_chunk",
15 "type": "filter"
16 },
17 {
18 "path": "x-amz-bedrock-kb-document-page-number",
19 "type": "filter"
20 }
21 ]
22}
8
9

Atlas displays a modal window to let you know your index is building.

10
11

The newly created index displays on the Atlas Search tab. While the index is building, the Status field reads Build in Progress. When the index is finished building, the Status field reads Active.

Note

Larger collections take longer to index. You will receive an email notification when your index is finished building.

In this section, you create a knowledge base to load custom data into your vector store.

1
  1. Log in to the AWS Console.

  2. In the upper-left corner, click the Services dropdown menu.

  3. Click Machine Learning, and then select Amazon Bedrock.

2

Amazon Bedrock doesn't grant access to FMs automatically. If you haven't already, follow the steps to add model access for the Titan Embeddings G1 - Text and Anthropic Claude V2.1 models.

3
  1. In the left navigation of the Amazon Bedrock console, click Knowledge Bases.

  2. Click Create and then select Knowledge base with vector store.

  3. Specify mongodb-atlas-knowledge-base as the Knowledge Base name.

  4. Click Next.

By default, Amazon Bedrock creates a new IAM role to access the knowledge base.

4
  1. Specify a name for the data source used by the knowledge base.

  2. Enter the URI for the S3 bucket that contains your data source. Or, click Browse S3 and find the S3 bucket that contains your data source from the list.

  3. Click Next.

    Amazon Bedrock displays available embedding models that you can use to convert your data source's text data into vector embeddings.

  4. Select the Titan Embeddings G1 - Text model.

5
  1. In the Vector database section, select Use an existing vector store.

  2. Select MongoDB Atlas and configure the following options:

    Screenshot of the Amazon Bedrock vector store configuration section.
    click to enlarge
    • For the Hostname, enter the URL for your Atlas cluster located in its connection string. The hostname uses the following format:

      <clusterName>.mongodb.net
    • For the Database name, enter bedrock_db.

    • For the Collection name, enter test.

    • For the Credentials secret ARN, enter the ARN for the secret that contains your Atlas cluster credentials. To learn more, see AWS Secrets Manager concepts.

  3. In the Metadata field mapping section, configure the following options to determine the MongoDB Vector Search index and field names that Atlas uses to embed and store your data source:

    Screenshot of the vector store field mapping configuration section.
    click to enlarge
    • For the Vector search index name, enter vector_index.

    • For the Vector embedding field path, enter embedding.

    • For the Text field path, enter bedrock_text_chunk.

    • For the Metadata field path, enter bedrock_metadata.

    Note

    Optionally, you can specify the Text search index name field to configure hybrid search. To learn more, see Hybrid Search with Amazon Bedrock and Atlas.

  4. If you configured an endpoint service, enter your PrivateLink Service Name.

  5. Click Next.

6

After reviewing the details for your knowledge base, click Create knowledge base to finalize your creation.

7

After Amazon Bedrock creates the knowledge base, it prompts you to sync your data. In the Data source section, select your data source and click Sync to sync the data from the S3 bucket and load it into Atlas.

When the sync completes, if you're using Atlas, you can verify your vector embeddings by navigating to the bedrock_db.test namespace in the Atlas UI.

In this section, you deploy an agent that uses MongoDB Vector Search to implement RAG and answer questions on your data. When you prompt this agent, it does the following:

  1. Connects to your knowledge base to access the custom data stored in Atlas.

  2. Uses MongoDB Vector Search to retrieve relevant documents from your vector store based on the prompt.

  3. Leverages an AI chat model to generate a context-aware response based on these documents.

Complete the following steps to create and test the RAG agent:

1
  1. In the left navigation for Amazon Bedrock, click Agents.

  2. Click Create Agent.

  3. Specify mongodb-rag-agent as the Name and click Create.

2

By default, Amazon Bedrock creates a new IAM role to access the agent. In the Agent details section, specify the following:

  1. From the dropdown menus, select Anthropic and Claude V2.1 as the provider and AI model used to answer questions on your data.

    Note

    Amazon Bedrock doesn't grant access to FMs automatically. If you haven't already, follow the steps to add model access for the Anthropic Claude V2.1 model.

  2. Provide instructions for the agent so that it knows how to complete the task.

    For example, if you're using the sample data, paste the following instructions:

    You are a friendly AI chatbot that answers questions about working with MongoDB.
  3. Click Save.

3

To connect the agent to the knowledge base that you created:

  1. In the Knowledge Bases section, click Add.

  2. Select mongodb-atlas-knowledge-base from the dropdown.

  3. Describe the knowledge base to determine how the agent should interact with the data source.

    If you're using the sample data, paste the following instructions:

    This knowledge base describes best practices when working with MongoDB.
  4. Click Add, and then click Save.

4
  1. Click the Prepare button.

  2. Click Test. Amazon Bedrock displays a testing window to the right of your agent details if it's not already displayed.

  3. In the testing window, enter a prompt. The agent prompts the model, uses MongoDB Vector Search to retrieve relevant documents, and then generates a response based on the documents.

    If you used the sample data, enter the following prompt. The generated response might vary.

    What's the best practice to reduce network utilization with MongoDB?
    The best practice to reduce network utilization with MongoDB is
    to issue updates only on fields that have changed rather than
    retrieving the entire documents in your application, updating
    fields, and then saving the document back to the database. [1]

    Tip

    Click the annotation in the agent's response to view the text chunk that MongoDB Vector Search retrieved.

5

To troubleshoot issues, see Troubleshooting the Amazon Bedrock Knowledge Base Integration.

Back

Build AI Agents

On this page