What is AWS Bedrock Knowledge Bases?
AWS Bedrock Knowledge Bases is a fully managed service that implements the entire RAG workflow - from data ingestion to retrieval and prompt augmentation. It allows you to:- Connect to Multiple Data Sources: Automatically fetch data from Amazon S3, Confluence, Salesforce, SharePoint, and more.
- Managed Vector Storage: Store embeddings in supported vector databases like Amazon Aurora, OpenSearch, Neptune, MongoDB, Pinecone, or Redis.
- Advanced Retrieval: Use semantic search and filtering for accurate information retrieval.
- Source Attribution: All retrieved information includes citations to improve transparency and minimize hallucinations.
Prerequisites
Before integrating AWS Bedrock Knowledge Bases with Portkey, ensure you have:- AWS Account with Bedrock access enabled.
- AWS Credentials with permissions to create and access Bedrock Knowledge Bases, configured in Portkey.
- Portkey Account with an API key.
- An IAM Role with the necessary permissions for Bedrock to access your data sources.
- A Vector Store (like Amazon OpenSearch Serverless) to store the indexed data.
Setup Guide
Step 1: Create an AWS Integration in Portkey
You need to connect your AWS account to Portkey. This allows Portkey to make authenticated requests to AWS on your behalf.1
Navigate to Integrations
Navigate to the Integrations section on Portkey’s Sidebar. This is where you’ll connect your LLM providers.
- Find Bedrock and click Connect.
- In the “Create New Integration” window:
- Enter a Name for reference (e.g.,
aws-bedrock-prod
). - Enter a Slug for the integration (e.g.,
aws-bedrock-prod
). - Enter your AWS Access Key ID, Secret Access Key, and Default Region.
- Enter a Name for reference (e.g.,
- Click Next Step.

The Slug you create here will be used with an
@
prefix as the provider
in your Portkey client initialization (e.g., @aws-bedrock-prod
).2
Configure Models
On the model provisioning page:
- Leave all models selected (or customize).
- Toggle “Automatically enable new models” if desired.
Step 2: Create a Knowledge Base
To create an AWS Bedrock Knowledge Base, you use Portkey’sput
method. This acts as a proxy, sending a signed request directly to the AWS PUT /knowledgebases/
API endpoint. Portkey handles the complex AWS Signature Version 4 authentication process for you.
When initializing the Portkey client, you must provide a custom_host
that points to the AWS Bedrock Agent API endpoint for your region.
AWS Docs: Create a knowledge base for Amazon Bedrock
Step 3: Retrieve from a Knowledge Base
Once your knowledge base is created and has finished syncing, you can query it using Portkey’spost
method. This request is sent to the AWS retrieve
API endpoint: POST /knowledgebases/{knowledgeBaseId}/retrieve
.
Important: For retrieval, the
custom_host
URL is different. You must use the Bedrock Agent Runtime endpoint for your region (e.g., bedrock-agent-runtime.us-east-1.amazonaws.com
).Step 4: Query the Knowledge Base and Generate a Response (RAG)
This step demonstrates the complete Retrieval-Augmented Generation (RAG) pipeline. First, we retrieve relevant context from the knowledge base. Then, we use that context to ground a large language model, enabling it to generate an informed response.Notice that we use two different Portkey client initializations. The first one includes a
custom_host
to target the Bedrock Agent Runtime for retrieval. The second one is a standard client for chat completion.Next Steps
Now that you can create and build a full RAG application with your knowledge base, you can explore other Portkey features to enhance your application:- Explore Portkey Observability to monitor your RAG pipeline.
- Set up Guardrails to ensure safe and compliant responses.
- Implement Prompt Management for your RAG prompts.
- Configure Fallbacks for high availability.
For enterprise support with your AWS Bedrock integration, contact our enterprise team.