cosmosdb-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@cosmosdb-mcplist containers in database 'orders' on account 'my-cosmos-account'"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Azure Cosmos DB MCP Server
An MCP (Model Context Protocol) server for Azure Cosmos DB. Compatible with any MCP client — Claude Code, Claude Desktop, Cursor, and others.
Exposes tools for listing accounts, databases, and containers, running SQL queries, reading and writing documents, and deleting items. The built-in Azure MCP server that ships with Claude Code provides limited Cosmos DB support — this project covers the full data plane, including writes.
Authentication uses DefaultAzureCredential, which picks up an active az login session automatically. Alternatively, a key can be provided via the AZURE_COSMOS_KEY environment variable. No secrets or keys are ever passed as tool arguments.
Requirements
Installation
Install uv and the Azure CLI if you don't have them:
macOS
brew install uv azure-cliLinux
curl -LsSf https://astral.sh/uv/install.sh | sh
curl -sL https://aka.ms/InstallAzureCLIDeb | sudo bash # Debian/UbuntuFor other Linux distributions see the Azure CLI install docs.
Windows
winget install --id=astral-sh.uv
winget install --id=Microsoft.AzureCLIConfiguration
Claude Code users:
claude mcp add --scope user cosmosdb -- uvx cosmosdb-mcpFor other MCP clients, add the following to your server configuration:
{
"mcpServers": {
"cosmosdb": {
"command": "uvx",
"args": ["cosmosdb-mcp"]
}
}
}Restart your MCP client after adding the server. No environment variables are required if you are authenticated with az login. Optional env vars:
AZURE_SUBSCRIPTION_ID— used bycosmosdb_list_accountsif setAZURE_COSMOS_KEY— use instead ofaz loginfor data plane operations
Installing from source
git clone https://github.com/BrianDeacon/cosmosdb-mcp
cd cosmosdb-mcp
uv sync
az loginThen configure with the cloned path:
{
"mcpServers": {
"cosmosdb": {
"command": "uv",
"args": ["run", "--directory", "/path/to/cosmosdb-mcp", "cosmosdb-mcp"]
}
}
}Tools
The account parameter accepts either a short account name (e.g. my-cosmos-account) or a full endpoint URL (e.g. https://my-cosmos-account.documents.azure.com). The prefix and suffix are added automatically if absent.
cosmosdb_list_accounts
List all Cosmos DB accounts in the current Azure subscription. The subscription is resolved automatically — first from the AZURE_SUBSCRIPTION_ID environment variable, then from the active az login session.
cosmosdb_list_databases
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
Returns a sorted JSON array of database names.
cosmosdb_list_containers
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
Returns a sorted JSON array of container names.
cosmosdb_get_container_info
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
| string | yes | Container name |
Returns partition key path, indexing policy, default TTL, unique key policy, and system properties.
cosmosdb_query_items
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
| string | yes | Container name |
| string | yes | SQL query (e.g. |
| integer | no | Max items to return (default 100, cap 1000) |
Cross-partition queries are enabled automatically. Use cosmosdb_query_items_to_file instead if the result set may be large.
cosmosdb_query_items_to_file
Same as cosmosdb_query_items but writes results to a file. Only the item count is returned in context, avoiding large payloads filling the context window.
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
| string | yes | Container name |
| string | yes | SQL query |
| string | yes | Path to write results as a JSON array |
| integer | no | Max items to return (default 100, cap 1000) |
cosmosdb_count_items
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
| string | yes | Container name |
| string | no | SQL WHERE clause body (e.g. |
Returns a JSON object with a count field.
cosmosdb_read_item
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
| string | yes | Container name |
| string | yes | Item |
| string | yes | Partition key value |
Returns the full item document as JSON.
cosmosdb_upsert_item
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
| string | yes | Container name |
| object | yes | Full item document — must include an |
Inserts or replaces the item. Returns the stored document including system fields.
cosmosdb_delete_item
Destructive. Deletes an item permanently.
Parameter | Type | Required | Description |
| string | yes | Cosmos DB account name or endpoint |
| string | yes | Database name |
| string | yes | Container name |
| string | yes | Item |
| string | yes | Partition key value |
Security
Authentication relies on
DefaultAzureCredentialorAZURE_COSMOS_KEY— keys are never passed as tool arguments, so secrets do not appear in conversation history.The
accountparameter only accepts account names and endpoint URLs, never connection strings.
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/BrianDeacon/cosmosdb-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server