Bedrock Batches
Use Amazon Bedrock Batch Inference API through LiteLLM.
| Property | Details | 
|---|---|
| Description | Amazon Bedrock Batch Inference allows you to run inference on large datasets asynchronously | 
| Provider Doc | AWS Bedrock Batch Inference โ | 
Overviewโ
Use this to:
- Run batch inference on large datasets with Bedrock models
- Control batch model access by key/user/team (same as chat completion models)
- Manage S3 storage for batch input/output files
(Proxy Admin) Usageโ
Here's how to give developers access to your Bedrock Batch models.
1. Setup config.yamlโ
- Specify mode: batchfor each model: Allows developers to know this is a batch model
- Configure S3 bucket and AWS credentials for batch operations
model_list:
  - model_name: "bedrock-batch-claude"
    litellm_params:
      model: bedrock/us.anthropic.claude-3-5-sonnet-20240620-v1:0
      #########################################################
      ########## batch specific params ########################
      s3_bucket_name: litellm-proxy
      s3_region_name: us-west-2
      s3_access_key_id: os.environ/AWS_ACCESS_KEY_ID
      s3_secret_access_key: os.environ/AWS_SECRET_ACCESS_KEY
      aws_batch_role_arn: arn:aws:iam::888602223428:role/service-role/AmazonBedrockExecutionRoleForAgents_BB9HNW6V4CV
    model_info: 
      mode: batch # ๐ SPECIFY MODE AS BATCH, to tell user this is a batch model
Required Parameters:
| Parameter | Description | 
|---|---|
| s3_bucket_name | S3 bucket for batch input/output files | 
| s3_region_name | AWS region for S3 bucket | 
| s3_access_key_id | AWS access key for S3 bucket | 
| s3_secret_access_key | AWS secret key for S3 bucket | 
| aws_batch_role_arn | IAM role ARN for Bedrock batch operations. Bedrock Batch APIs require an IAM role ARN to be set. | 
| mode: batch | Indicates to LiteLLM this is a batch model | 
2. Create Virtual Keyโ
curl -L -X POST 'https://{PROXY_BASE_URL}/key/generate' \
-H 'Authorization: Bearer ${PROXY_API_KEY}' \
-H 'Content-Type: application/json' \
-d '{"models": ["bedrock-batch-claude"]}'
You can now use the virtual key to access the batch models (See Developer flow).
(Developer) Usageโ
Here's how to create a LiteLLM managed file and execute Bedrock Batch CRUD operations with the file.
1. Create request.jsonlโ
- Check models available via /model_group/info
- See all models with mode: batch
- Set modelin .jsonl to the model from/model_group/info
{"custom_id": "request-1", "method": "POST", "url": "/v1/chat/completions", "body": {"model": "bedrock-batch-claude", "messages": [{"role": "system", "content": "You are a helpful assistant."}, {"role": "user", "content": "Hello world!"}], "max_tokens": 1000}}
{"custom_id": "request-2", "method": "POST", "url": "/v1/chat/completions", "body": {"model": "bedrock-batch-claude", "messages": [{"role": "system", "content": "You are an unhelpful assistant."}, {"role": "user", "content": "Hello world!"}], "max_tokens": 1000}}
Expectation:
- LiteLLM translates this to the bedrock deployment specific value (e.g. bedrock/us.anthropic.claude-3-5-sonnet-20240620-v1:0)
2. Upload Fileโ
Specify target_model_names: "<model-name>" to enable LiteLLM managed files and request validation.
model-name should be the same as the model-name in the request.jsonl
- Python
- Curl
from openai import OpenAI
client = OpenAI(
    base_url="http://0.0.0.0:4000",
    api_key="sk-1234",
)
# Upload file
batch_input_file = client.files.create(
    file=open("./bedrock_batch_completions.jsonl", "rb"), # {"model": "bedrock-batch-claude"} <-> {"model": "bedrock/us.anthropic.claude-3-5-sonnet-20240620-v1:0"}
    purpose="batch",
    extra_body={"target_model_names": "bedrock-batch-claude"}
)
print(batch_input_file)
curl http://localhost:4000/v1/files \
    -H "Authorization: Bearer sk-1234" \
    -F purpose="batch" \
    -F file="@bedrock_batch_completions.jsonl" \
    -F extra_body='{"target_model_names": "bedrock-batch-claude"}'
Where is the file written?:
The file is written to S3 bucket specified in your config and prepared for Bedrock batch inference.
3. Create the batchโ
- Python
- Curl
...
# Create batch
batch = client.batches.create( 
    input_file_id=batch_input_file.id,
    endpoint="/v1/chat/completions",
    completion_window="24h",
    metadata={"description": "Test batch job"},
)
print(batch)
curl http://localhost:4000/v1/batches \
    -H "Authorization: Bearer sk-1234" \
    -H "Content-Type: application/json" \
    -d '{
        "input_file_id": "file-abc123",
        "endpoint": "/v1/chat/completions",
        "completion_window": "24h",
        "metadata": {"description": "Test batch job"}
    }'
FAQโ
Where are my files written?โ
When a target_model_names is specified, the file is written to the S3 bucket configured in your Bedrock batch model configuration.
What models are supported?โ
LiteLLM only supports Bedrock Anthropic Models for Batch API. If you want other bedrock models file an issue here.