🚀 New Major Release — Azure MCP Server 2.0
We're thrilled to announce the second major release of the Azure MCP Server! Version 2.0 represents a significant evolution from the 1.0 release, bringing remote HTTP deployment, dramatically expanded Azure service coverage, comprehensive security hardening, and major performance improvements. This release spans over 40 beta iterations and hundreds of contributions.
- Deploy as a Remote MCP Server: Deploy the Azure MCP Server as a shared, multi-user HTTP service with Entra ID authentication and On-Behalf-Of (OBO) authorization
- Use with Sovereign Clouds: Full support for Azure Government and Azure China clouds across multiple services
- More Docker Options: AMD64 and ARM64 images are now available. Trimmed binaries cut image size by ~60% compared to initial Docker builds
- New Installation Methods: Added two new distribution formats:
- PyPI: With UVX support for Python/uv-based workflows
- MCP Bundles (
.mcpb): A portable format compatible with Claude Desktop
- Security Hardening: Comprehensive input validation, SSRF protection, SQL/KQL injection prevention, query parameterization, and endpoint validation across all services
- User Confirmation Prompts: Added user confirmation prompts for sensitive and destructive operations via MCP elicitation
- Foundry Integration: Added integration with the external Azure AI Foundry MCP server (
https://mcp.ai.azure.com) providing agent lifecycle, batch evaluation, prompt optimization, and project connection management tools - More Tools: Increased tool coverage from 170+ to 260+ across 50+ services
- Improved Performance: Server startup reduced from ~20s to ~1-2s when proxied MCP servers are enabled (Microsoft Documentation, Azure Developer CLI, Azure AI Foundry)
Install the Azure MCP Server from your preferred platform:
- VS Code: Install the Azure MCP Server extension
- Visual Studio 2022: Install GitHub Copilot for Azure
- Visual Studio 2026: Install the Azure and AI Development workload
- Claude and GitHub Copilot CLI: Install the Azure Copilot Plugin
- IntelliJ IDEA: Install the Azure Toolkit for IntelliJ
- Eclipse IDE: Install the Azure Toolkit for Eclipse
- NuGet: Run
dotnet tool install -g Azure.Mcp --version 2.0.0 - npm: Run
npx @azure/mcp@2.0.0 - Docker: Run
docker pull mcr.microsoft.com/azure-mcp:2.0.0 - PyPI: Run
pip install msmcp-azure==2.0.0 - MCP Bundles: Download the
.mcpbfile for your platform/architecture and open it with your client, like Claude Desktop:
- Complete Command Reference
- Authentication
- Remote Server Deployment
- Connecting to Sovereign Clouds
- Troubleshooting
- Contributing Guidelines
This release was made possible by the incredible efforts of our engineering team, partners, contributors, and the invaluable feedback from our users and the open-source community. We want to extend a huge thank you to everyone who contributed, tested, and provided feedback throughout the development of Azure MCP Server 2.0!
For a complete history of changes included in this release, see entries for versions 2.0.0-beta.1 through 2.0.0-beta.40.
- Added query parameterization for SQL-based tools (MySQL, PostgreSQL, Cosmos DB) and input sanitization for KQL-based tools (Kusto, Monitor, Deploy), with shared helpers in
Microsoft.Mcp.Core. [#2362]
- Added endpoint validation for the namespace parameter in
servicebustools to ensure it resolves to a valid Azure Service Bus domain. [#2349]
- Added input validation for Azure Storage account names in
StorageService. [#2350]
- Replaced structured logging of entire options objects with explicit non-sensitive identifiers in error log statements across all commands. [#2336]
- Added URI validation for disk creation source parameter to enforce HTTPS and Azure Blob Storage endpoints. [#2339]
- Fix endpoint validation on non-Public cloud environments. [#2322]
- Added a
ClientNameoption andToolAreamodel property to theplugin-telemetrytool.ClientTypewill be deprecated once usage data decreases. [#2324]
- Added service name validation for Azure AI Search tools. [#2307]
- Added skill name and tool name validation to the
plugin-telemetrytool. Skill names are validated against an allowlist to prevent logging of customer-defined custom skill names. Tool names are validated by stripping known client prefixes (Claude Code, VS Code, Copilot CLI) and matching against registered commands or area names, with normalized names logged for consistent telemetry. Added an allowlist for Azure extension tools that are not azmcp commands but still tracked. Expanded the plugin file-reference allowlist with additional azure-enterprise-infra-planner reference paths. [#2291] - Refactored
PluginTelemetryCommandto use constructor injection for allowlist providers and lazy resolution ofICommandFactoryviaIServiceProviderto avoid circular dependency during startup. [#2291]
- Configured the right audience based on Cloud configuration when creating SDK clients for tools in:
- Fixed JSON deserialization issues for
resourcehealthevents with timezone-less datetime values. [#2293]
- Added
--dangerously-disable-retry-limitsserver start option to bypass retry policy bounds enforcement when explicitly required. [#2239]
- Breaking: Removed support for custom URL-based authority hosts in the
--cloudoption. The option now accepts only well-known cloud names. Unrecognized values now throw anArgumentExceptioninstead of defaulting to the public cloud. Supported values are: [#2257]AzureCloudAzurePublicCloudPublicAzurePublicAzureChinaCloudChinaAzureChinaAzureUSGovernmentAzureUSGovernmentCloudUSGovUSGovernment
- Enforced upper bounds on retry policy values to prevent excessively large retry configurations. [#2239]
- Bumped
@azure/msal-browserto 5.2.0+ to comply with Component Governance requirements. [#2260] - Removed references to the non-existent
--public-access-levelparameter from thestorage_blob_container_createtool description and associated e2e test prompts. [#2264]
- Enforced read-only and HTTP mode restrictions at tool execution time, not just during tool listing. [#2226]
- Improved reliability by adding regex timeouts to prevent hangs, limiting large resource listings, and allowing cancellation to propagate correctly through exception handling. [#2223]
- Fixed Cosmos DB cache key generation to include the authentication method, preventing incorrect client reuse across authentication types. [#2217]
- Fixed validation gap in
BaseAzureResourceServicewhere theadditionalFilterparameter could be concatenated into Resource Graph queries without validation. Pipe operators are now rejected. [#2217] - Added input validation for ledger names in
ConfidentialLedgerServiceto ensure only valid characters are accepted. [#2211] - Fixed elicitation for GitHub Copilot CLI by updating from
UntitledSingleSelectEnumSchematoTitledSingleSelectEnumSchema. [#2253] - Fixed incorrect SignalR caching where runtime results were not stored in the cache, causing every request to re-fetch instead of returning cached data. [#2254]
- Added
CacheKeyBuilderto construct cache keys using characters disallowed in Azure resource and subscription names, preventing cache collisions in multi-client remote scenarios. [#2259] - Added vault name validation in
KeyVaultServiceto prevent unsafe input from being interpolated into Key Vault and Managed HSM URIs. [#2238]
- Updated secret elicitation to require explicit user confirmation before proceeding with sensitive operations. [#2197]
- Extended elicitations/user consent prompts to cover destructive operations (delete, modify, create) in addition to secret operations, and consolidated both into a single prompt to avoid duplicate confirmation. [#2208]
- Added IPv4 format validation and blocked dangerous IP ranges in the
sql_server_firewall-rule_createcommand to prevent overly permissive firewall rules. [#2206] - Improved
HttpRequestExceptionhandling to return the actual HTTP status code when available instead of defaulting to503 Service Unavailable. [#2200]
- Added blocklist validation for security-sensitive PostgreSQL server parameters (audit logging, TLS/SSL, authentication, shared libraries, row-level security) in the
server param setcommand to prevent accidental weakening of server security. [#2164] - Added
--public-network-accessoption to theredis_createcommand to control public network access for Azure Managed Redis resources (defaults to disabled). [#2179]
- Centralized Foundry and Azure OpenAI endpoint validation using the shared
EndpointValidatorwith sovereign cloud support. [#2162] - Added file path validation and canonicalization for the
speech_stt_recognizeandspeech_tts_synthesizecommands. [#2162] - Added skill name allowlist validation to the
plugin-telemetrytool to prevent logging of customer-defined custom skill names, and expanded the plugin file-reference allowlist with additionalazure-enterprise-infra-plannerreference paths. [#2149] - Removed structured logging of the full options payload from the
sql_server_createcommand to prevent accidental exposure of sensitive values. [#2158] - Updated Docker release pipeline to publish additional minor version tags (e.g.,
2.0,2.0-amd64,2.0-arm64) allowing consumers to pin to a minor release stream. [#2144]
- Fixed PostgreSQL and MySQL server name validation to require allowed Azure domain suffixes when a fully qualified domain name is provided. [#2159]
- Fixed Cosmos DB credential authentication to strictly honor the requested authentication method instead of falling back to account-key authentication. [#2162]
- Fixed snapshot lookup in the
FileSharesnamespace to use exact resource ID matching instead of substring matching. [#2168] - Improved Cosmos DB query validator to detect a broader range of boolean tautology patterns. [#2171]
- Fixed the
sql_server_createcommand to default--public-network-accesstoDisabledfor secure-by-default server creation. [#2181]
- Added new
computecommands to delete VMs and VM scale sets with--force-deletionsupport: [#2065]compute_vm_deletecompute_vmss_delete
- Added
containerapps_listtool to list Azure Container Apps in a subscription. [#1981] - Enhanced
monitorinstrumentation tools with framework-aware onboarding for .NET, Node.js, and Python, including guidance for Application Insights 3.x migration and Azure Monitor Distro adoption, and added thesend_enhancement_selecttool to submit selected enhancements to an active orchestrator session. [#2115] - Added default subscription resolution from the Azure CLI profile (
~/.azure/azureProfile.json) for all subscription-scoped commands, falling back toAZURE_SUBSCRIPTION_IDenvironment variable. [#1974] - Added
group_resource_listtool to list all resources within an Azure Resource Group, including generic and non-specialized resources. [#1975]
- Breaking: Renamed the following
monitortools to use dash-separated names instead of underscores: [#2134]get-learning-resourceorchestrator-startorchestrator-nextsend-brownfield-analysis
- Breaking: Narrowed the
subscription listcommand response model to include only (subscriptionId,displayName,state,tenantId,isDefault) instead of the full Azure SDKSubscriptionDatatype. [#1974] - Improved tool descriptions to enhance LLM selection accuracy for the following tools: [#2131]
extension_azqrextension_cli_generateextension_cli_install
- Breaking: Moved the following tools from the
monitorinstrumentationnamespace to themonitornamespace: [#2087]list_learning_resourcesget_learning_resourceorchestrator_startorchestrator_nextsend_brownfield_analysis
- Breaking: Consolidated the
list_learning_resourcesandget_learning_resourcetools into a singleget_learning_resourcetool in themonitornamespace. [#2113] - Extended command telemetry to include additional attributes (
plugin-version,skill-name,skill-version). [#2114] - Reviewed MCP tool Command definitions and resolved validation inconsistencies, aligning implementations with tool development guidelines and improving consistency across multiple tool areas. [#2086]
- Added new
computetool for deleting Azure managed disks: [#2059]compute_disk_delete
- Added GitHub API rate limiting handling, runtime configuration support, and live test infrastructure for the
Azure.Mcp.Tools.Functionstoolset. [#2071] - Removed hardcoded Model Context Protocol version in favor of using the latest supported by the C# SDK. [#2101]
- Added tenant parameter support to Azure Resource Graph queries in BaseAzureResourceService, enabling queries to run against the intended tenant context. [#1945]
- Fixed SQL injection vulnerability in MySQL query validation that allowed bypassing safety checks via version-specific comments and UNION-based attacks. [#2083]
- Hardened Postgres SQL query validator to block set-operation keywords (UNION, INTERSECT, EXCEPT), additional dangerous system catalogs, and fixed false-positive comment detection inside string literals. [#2096]
- Hardened SSRF protection in EndpointValidator against IPv6 transition mechanism bypass vectors (IPv4-mapped, 6to4, Teredo, NAT64, NAT64v2, IPv4-compatible), added wildcard DNS blocklist, trailing-dot FQDN normalization, and sanitized error messages to prevent IP address leakage. [#2066]
- Enhanced Azure File Shares private endpoint connection management with improved reliability and updated SDK support. [#1823]
- Added new
monitorinstrumentationtools that analyze a local workspace and return step-by-step guidance to instrument applications with Azure Monitor: [#1960]list_learning_resourcesget_learning_resourceorchestrator_startorchestrator_nextsend_brownfield_analysis
- Enhanced the
wellarchitectedframework serviceguide gettool to act as a list command when no service parameter is provided, reducing the total number of tools. [#2020] - Expanded the PostgreSQL query validator blocklist with additional dangerous functions and system catalogs. [#2067]
- Added a hidden
plugin-telemetrytool to emit skill/tool invocation telemetry for agent scenarios (e.g., Copilot CLI), including validated and sanitized file references via an embedded allowlist. [#1979]
- Breaking: Removed the following tools from the
foundryextensionsnamespace: [#2037]agents_get-sdk-samplethreads_createthreads_listthreads_get-messages
- Improved testability of the following namespaces by removing a dependency on
CommandContext.ServiceProviderinExecuteAsync: - Refactored tools in the following namespaces to use constructor dependency injection instead of resolving services via
context.GetService<T>()inExecuteAsync: - Reintroduced capturing error information in telemetry with standard
exception.message,exception.type, andexception.stacktracetelemetry tags, replacing theErrorDetailstag. [#1942] - Improved descriptions for better LLM selection accuracy for the following:
- Centralized ARM access token acquisition in
BaseAzureServiceviaGetArmAccessTokenAsync, eliminating duplicated inline credential and token fetching logic across service implementations. [#2033] - Updated Landing Zone URL in the
azuremigratetools to use aka.ms links. [#2028] - Standardized
CacheServiceTTLs across services by introducing centralizedCacheDurationstiers (subscription12h→2h; service data1h→5m). [#1973] - Switched Docker publishing to 1ES tasks for pushing images to ACR and split the release process into separate load and multi-arch manifest publish steps. [#2069]
- Updated
eng/commonfrom thetoolsrepo, pulling in shared engineering pipeline/script changes and dependency/lockfile refreshes. [#2030] - Updated .NET SDK from
10.0.103to10.0.201. [#2072] - Updated
Azure.ResourceManager.FileSharesfrom1.0.0-beta.1to1.0.0-beta.2. [#1823] - Updated
Azure.Bicep.Typesfrom0.6.27to0.6.50. [#1574]
- Improved the
applens resource diagnosetool to use ARG-based resource discovery with optional subscription, resource group, and resource type parameters. [#2018] - Added filtering on
LocalRequiredwhen running in remote mode. [#2017] - Fixed the
postgres listtool incorrectly requiring--resource-groupand--userwhen listing servers at the subscription scope. Both parameters are now optional as intended. [#2015] - Fixed a connection string injection vulnerability in PostgreSQL and MySQL tools by using parameterized connection string builders instead of string interpolation. [#2056]
- Fixed KQL injection vulnerabilities in Kusto tools where user-controlled table names were directly interpolated into KQL commands without escaping, allowing arbitrary command execution. [#2070]
- Fixed credential chain crash from
InteractiveBrowserCredentialfailure. [#2076]
- Added compute disk create and compute disk update commands for managing Azure managed disks. [#1936]
- Added Azure Device Registry namespace list command (
azmcp deviceregistry namespace list) [#1961] - Added Azure Functions toolset with three new tools:
functions_language_listfor listing supported languages,functions_project_getfor retrieving project initialization files, andfunctions_template_getfor listing and fetching function template source code. [#1959] - CodeToCloud feature parity improvements for Deploy and Quota areas: [#1663]
- Support deployment using Azure CLI with Bicep/Terraform
- Support creation of a deploy-to-existing-resources plan
- New resource type support in quota checks, including SQL, MySQL, and CosmosDB
- New IaC rules added for better support regarding code quality, configuration success and security
- Breaking:
azmcp deploy pipeline guidance getoption renames and removals: [#1663]--use-azd-pipeline-configrenamed to--is-azd-project--azd-iac-optionsrenamed to--iac-options--organization-name,--repository-name, and--github-environment-nameoptions removed--pipeline-platformand--deploy-optionadded as new options This new design allows an overall better user experience to generate CI/CD pipeline to Azure.
- AzureIsv: Improved testability by removing dependency on CommandContext.ServiceProvider in ExecuteAsync. [#1902]
- Compute: Improved testability by removing dependency on CommandContext.ServiceProvider in ExecuteAsync. [#1914]
- Refactored Azure Migrate commands to use constructor dependency injection instead of context.GetService() [#1909]
- Refactored
FunctionAppGetCommandto use constructor dependency injection forIFunctionAppServiceinstead of resolving it viacontext.GetService<T>()inExecuteAsync. [#1991] - Refactored
Azure.Mcp.Tools.Extensioncommands to use constructor dependency injection instead of resolving services viacontext.GetService<T>()inExecuteAsync. [#1988] - Refactored
Azure.Mcp.Tools.Grafanato use constructor dependency injection instead of resolving services viacontext.GetService<T>()inExecuteAsync. [#1992]
- Added
DeviceCodeCredentialsupport for headless environments (Docker, WSL, SSH tunnels, CI) where browser-based interactive authentication is unavailable. It is automatically used as a last-resort fallback in the default anddevcredential chains, and can also be selected exclusively by settingAZURE_TOKEN_CREDENTIALS=DeviceCodeCredential. Not available instdioorhttpserver transport modes. [#1908] - Added Azure Compute VM create/update and VMSS create/update. [#1705]
- Added Azure Well-Architected Framework service guide tool to provide architectural best practices, design patterns, and recommendations based on the five pillars: reliability, security, cost optimization, operational excellence, and performance efficiency. [#1964]
- AppLens: Improved testability by removing dependency on CommandContext.ServiceProvider in ExecuteAsync. [#1884]
- Acr: Improved testability by removing dependency on CommandContext.ServiceProvider in ExecuteAsync. [#1881]
- Aks: Improved testability by removing dependency on CommandContext.ServiceProvider in ExecuteAsync. [#1883]
- Authorization: Improved testability by removing dependency on CommandContext.ServiceProvider in ExecuteAsync. [#1901]
- Advisor: Improved testability by removing dependency on CommandContext.ServiceProvider in ExecuteAsync. [#1882]
- Refactored
ApplicationInsightstools to use constructor dependency injection. [#1899]
- Added new tools available via the external Azure AI Foundry MCP server (https://mcp.ai.azure.com) that provide capabilities not previously available in Azure MCP Server: [#1771]
- agent_container_control: Control an agent container
- agent_container_status_get: Get the status of an agent container
- agent_definition_schema_get: Get the schema for an agent definition
- agent_invoke: Invoke an agent interactively
- evaluation_agent_batch_eval_create: Create a batch evaluation run for an agent
- evaluation_dataset_batch_eval_create: Create a batch evaluation run using a dataset
- evaluator_catalog_create: Create a custom evaluator in the catalog
- evaluator_catalog_delete: Delete an evaluator from the catalog
- evaluator_catalog_get: Get an evaluator from the catalog
- evaluator_catalog_update: Update an evaluator in the catalog
- project_connection_create: Create a connection in a Foundry project
- project_connection_delete: Delete a connection from a Foundry project
- project_connection_get: Get details of a Foundry project connection
- project_connection_list: List connections in a Foundry project
- project_connection_list_metadata: List metadata for connections in a Foundry project
- project_connection_update: Update a connection in a Foundry project
- prompt_optimize: Optimize a prompt for a specific model
- Added
eng/scripts/Preflight.ps1developer CI preflight check script with format, spelling, build, tool metadata, README validation, unit test, and AOT analysis steps. [#1893] - Added tools for web app diagnostics. [#1907]
- Breaking: Foundry tools previously under the
foundrynamespace have moved to the newfoundryextensionsnamespace within Azure MCP Server, retaining direct in-process access to Azure OpenAI, knowledge indexes, agent threads, and resources: [#1771]- foundryextensions_agents_get_sdk_sample: Get an SDK code sample for Azure AI Foundry Agents
- foundryextensions_knowledge_index_list: List knowledge indexes in a Foundry project
- foundryextensions_knowledge_index_schema: Get the schema of a knowledge index
- foundryextensions_openai_chat_completions_create: Create a chat completion using an Azure OpenAI deployment
- foundryextensions_openai_create_completion: Create a text completion using an Azure OpenAI deployment
- foundryextensions_openai_embeddings_create: Create embeddings using an Azure OpenAI deployment
- foundryextensions_openai_models_list: List available Azure OpenAI models
- foundryextensions_resource_get: Get details about a Foundry resource
- foundryextensions_threads_create: Create a new agent thread
- foundryextensions_threads_get_messages: Get messages from an agent thread
- foundryextensions_threads_list: List agent threads
- Breaking: The following Azure AI Foundry tools were renamed as part of the migration to the external Foundry MCP server (https://mcp.ai.azure.com). See the Breaking Changes entry for the full list of removed tools: [#1771]
- foundry_agents_list → agent_get
- foundry_agents_create → agent_update
- foundry_agents_connect → agent_invoke
- foundry_models_list → model_catalog_list
- foundry_models_deploy → model_deploy
- foundry_models_deployments_list → model_deployment_get
- foundry_agents_query-and-evaluate → evaluation_agent_batch_eval_create
- foundry_agents_evaluate → evaluator_catalog_get
- Added Cloud to telemetry to denote which Azure cloud the tool is using. [#1918]
- Updated Microsoft.Identity.Web and Microsoft.Identity.Web.Azure from 4.4.0-preview.1 to 4.4.0. [#1896]
- Fixed JSON Schema generation for OpenAI Codex model compatibility: added
additionalProperties: false, enum types now emit asstringwith named values, addedenumarray to enum properties, empty descriptions are omitted instead of serialized as empty strings. [#1893] - Fixed argument parsing to support camelCase parameter names and flat argument structures sent by Codex and other OpenAI models. [#1893]
- Fixed flaky VisualStudioToolNameTests by using in-process CommandFactory instead of external process with timeout. [#1893]
- Fixed Linux stdio watcher regression where using CWD as content root could exhaust inotify watchers (ENOSPC). Host builders now use AppContext.BaseDirectory as content root. [#1935]
- Added App Service web app deployment retrieval tool. [#1898]
- Breaking: Consolidated
sql_db_showandsql_db_listcommands into a singlesql_db_getcommand, andsql_server_showandsql_server_listcommands into a singlesql_server_getcommand. [#1897]
- Fixed multiple bugs for the Azure Workbooks tool [#1646]
- Disable external process commands (
azqr) in HTTP remote mode for security. [#1522] - Added the
appservice_webapp_gettool to retrieve details about Web Apps. [#1810] - Added the following App Service Web App settings tools: [#1831]
appservice_webapp_settings_get-appsettings: Get application settings for an App Service Web Appappservice_webapp_settings_update-appsettings: Update application settings for an App Service Web App
- Breaking: Consolidated the
cosmos_account_list,cosmos_database_list, andcosmos_database_container_listcommands into a singlecosmos_listcommand. [#1821] - Improve testability by removing dependency on
CommandContext.ServiceProviderin theExecuteAsync()method for App Configuration*Commandclasses. [#1815]
- Fixed
azqrtool calls failing due tocostsparameter removed in latest version. [#1739] - Fixed OAuth Protected Resource Metadata flows in Azure Container Apps (ACA) by reading the
X-Forwarded-Protoheader (opt-in viaAZURE_MCP_DANGEROUSLY_ENABLE_FORWARDED_HEADERS) to correctly construct the scheme inWWW-Authenticatechallenge responses and the OAuth PRM endpoint. [#1820]
- The Azure MCP Server is now also available as an MCP Bundle (
.mcpb), compatible with clients such as Claude Desktop and Claude Code. [#1681] - Added sovereign cloud endpoint support for the AppLens, Application Insights, App Service, Azure Migrate, Confidential Ledger, Cosmos, Extension, Foundry, Key Vault, Kusto, Marketplace, Monitor, MySql, Postgres, Pricing, Quota, Resource Health, Search, Service Fabric, Speech, and Storage services. [#1729]
- Added endpoint validation for Azure Communication Services, App Configuration, and Container Registry. [#1765]
- Added the "createmigrateproject" action in the
azuremigrate_platformlandingzone_requesttool to create a new Azure Migrate project if one doesn't exist. [#1724]
- Breaking: Consolidated Resource Health availability-status commands: merged
resourcehealth_availability-status_getandresourcehealth_availability-status_listinto a single dual-moderesourcehealth_availability-status_getcommand. The command now accepts an optional--resourceIdparameter: when provided, it returns a single resource's availability status; when omitted, it lists all resources. Tool name changed fromresourcehealth_availability-status_listto use onlyresourcehealth_availability-status_get. [#1796] - Switched Docker base image to
runtime-deps:10.0-alpine. Since the server binary is self-contained, the full ASP.NET runtime base is unnecessary. Expected ~20-25% image size reduction (for example, azure-mcp images arm64: 648MB to ~482MB, amd64: 784MB to ~624MB). [#1782] - Improved the
storage_table_listtool description for better LLM tool selection. [#1800]
- (Undocumented fix from version
2.0.0-beta.21) Added validation logic for endpoint parameters in Foundry tools. [#1658] - Fixed error handling to ensure error messages are preserved for missing parameters. [#1751]
- Enabled trimmed binary for Docker and HTTP transport support for all distributions. [#1760]
- Add
McpServerNameto telemetry. [#1755]
- Added two new Azure Service Fabric managed clusters tools: [#1696]
servicefabric_managedcluster_node_get: List all nodes in a Service Fabric managed clusterservicefabric_managedcluster_nodetype_restart: Restart nodes from a Service Fabric managed cluster
- Resolve gaps in the capture of certain telemetry tags. [#1718]
- Improved formatting of the
--helpCLI command and added examples. [#1640] - Added prompt templates documentation (
docs/prompt-templates.md) showing how to set tenant and subscription context once using.github/copilot-instructions.mdor at the start of chat sessions, eliminating repetitive prompting. [#1744] - Improved error message for tenant mismatch authentication errors with actionable resolution steps. [#1737]
- Added
compute_disk_gettool to retrieve Azure managed disk information that supports listing all disks in a subscription, listing disks in a resource group, and getting specific disk details. [#1559] - Added support for OAuth-protected registry servers by allowing
oauthScopesinregistry.jsonfor HTTP-transport servers. [#1509]
- Consolidated KeyVault get/list commands - separate list commands removed: [#1653]
- Removed keyvault_key_list - use keyvault_key_get without providing a key name
- Removed keyvault_secret_list - use keyvault_secret_get without providing a secret name
- Removed keyvault_certificate_list - use keyvault_certificate_get without providing a certificate name
- Consolidated Monitor WebTest commands – (get/list merged into monitor_webtests_get, create/update merged into monitor_webtests_createorupdate): [#1678]
- Removed monitor_webtests_list – use monitor_webtests_get without providing a WebTest name
- Removed monitor_webtests_update – use monitor_webtests_createorupdate for both create and update scenarios
- Consolidated MySQL and PostgreSQL list commands – separate server/database/table list tools removed: [#1710]
- Removed postgres_server_list, postgres_database_list, postgres_table_list – use postgres_list with appropriate parameters to route hierarchically
- Removed mysql_server_list, mysql_database_list, mysql_table_list – use mysql_list with appropriate parameters to route hierarchically
- Consolidated Load Testing TestRun commands – separate list/update commands removed: [#1711]
- Removed loadtesting_testrun_list – use loadtesting_testrun_get for retrieving test runs
- Removed loadtesting_testrun_update – use loadtesting_testrun_createorupdate for both create and update scenarios
- Added processor architecture to captured telemetry. [#1691]
- AMD64 and ARM64 Docker images of the Azure MCP Server are now available. [#1651]
- Added CORS policy to restrict cross-origin requests to localhost when running in unauthenticated development environment. [#1609]
- Fixed elicitation prompts failing with 'Form mode elicitation requests require a requested schema' error by using simple accept/decline prompts instead of form-based schemas for sensitive tool confirmations. [#1668]
- Added log telemetry support for customer-owned AppInsights. [#1638]
- Added support for dangerous persistent logging configuration in VSIX extension, allowing users to specify a directory for detailed debug logs via the azureMcp.dangerouslyWriteSupportLogsToDir setting. [#1639]
- Improved input validation in ResourceHealth and Kusto tools: [#1634]
- ResourceHealth: Added resource ID validation using Azure.Core.ResourceIdentifier.Parse()
- Kusto: Added cluster URI validation with domain suffix and hostname allowlist
- Added cancellation token support so deploy operations can be cancelled cleanly and consistently. [#1627]
- Improved cancellation behavior for async enumerators by adding support for
CancellationToken, making it easier to correctly stop long-running or streaming async iteration. [#1649]
- Added Azure Compute VM operations with flexible compute vm get command that supports listing all VMs in a subscription, listing VMs in a resource group, getting specific VM details, and retrieving VM instance view with runtime status: [#1482]
compute_vm_get
- Added Virtual Machine Scale Set (VMSS) get operations to retrieve VMSS information including listing across subscriptions or resource groups, getting specific VMSS details, and retrieving individual VM instances within a scale set: [#1482]
compute_vmss_get
- Added Azure Retail Pricing MCP tool for querying Azure service pricing information: [#1621]
pricing_get
- Added support for new versions of Azure AI Search knowledge bases and those set to 'minimal' reasoning effort. [#1422]
- Removed ErrorDetails from telemetry. [#1625]
- Updated bestpractices tool description to ask LLM to use azure skills. [#1622]
- Updated swa app deployment instructions in bestpractices tool. [#1637]
- Added host information to tools execution telemetry. [#1604]
- Fixed async disposal pattern in CosmosService by implementing IAsyncDisposable and replacing async void Dispose with proper async disposal. [#1532]
- Fixed a regression that disabled telemetry for remote Azure MCP server. [#1602]
- Added AreResultsTruncated to tools that list resources using Resource Graph. [#1526]
- Improved server startup performance by parallelizing external MCP server initialization, reducing startup time from ~20 seconds to ~1-2 seconds when using registry-based servers. [#1534]
- Added MCP tool for List Advisor Recommendations -
advisor_recommendations_list. [#1519] - Added new Azure Managed Lustre fileshare blob import management tools: [#1492]
managedlustre_fs_blob_import_createmanagedlustre_fs_blob_import_getmanagedlustre_fs_blob_import_cancelmanagedlustre_fs_blob_import_delete
- Added Sovereign Cloud support for the Azure MCP server. Select services require additional changes and remain unsupported. [#1533]
- Added support for Azure Migrate platform landing zone operations with two new commands: [#1524]
azmcp_azuremigrate_platformlandingzone_getguidance- provides scenario-based guidance for Azure Landing Zone configurations including policy search and archetype-based policy listingazmcp_azuremigrate_platformlandingzone_request- enables checking, generating, updating and downloading, platform landing zone configurations based on user inputs
- Added UVX support, enabling running MCP servers via
uvxfor improved Python/uv-based workflows. [#1359]
- Optimized
--versionflag to bypass full service initialization, reducing response time from ~10s to <3s. [#1531] - Replaced the in-house
HttpClientServicewith the built-in .NETIHttpClientFactoryfor HTTP client creation/management, improving configurability and aligning with recommended .NET patterns. [#1564] - Added the internal utility
ToolMetadataExporterto export current azmcp tool metadata (supporting Azure MCP metadata/telemetry documentation workflows). [#992]
- Improved Foundry project endpoint parameter description. [#1555]
- Update outdated schema version within
server.jsonto2025-12-11[#1527]
- Added 12 Azure File Shares tools for managing Azure managed file shares: [#1419]
- File Share tools (5): CheckNameAvailability, Create, Delete, Get, Update
- File Share Snapshot tools (4): Create, Delete, Get, Update
- Informational tools (3): GetLimits, GetProvisioningRecommendation, GetUsageData
- Added support for listing and viewing individual Azure Policy assignments in subscriptions or scopes. [#1483]
- Breaking: Renamed the
--insecure-disable-elicitationserver startup option to--dangerously-disable-elicitationto align with the naming convention used by other dangerous options (e.g.,--dangerously-disable-http-incoming-auth). The old option name is no longer supported. [#1374] - Breaking: Renamed the
storagesync_cloudendpoint_triggerchangedetectiontool tostoragesync_cloudendpoint_changedetection. The--directory-pathparameter is now required. Added new optional parameters:--change-detection-mode(supports 'Default' or 'Recursive') and--paths(array of relative paths for change detection). - Breaking: Renamed the following commands: [#1474]
get_bestpractices_get→get_azure_bestpractices_getget_bestpractices_ai_app→get_azure_bestpractices_ai_app
- Updated repository to build projects using .NET 10. [#1221]
- Switched to
Azure.ResourceManager.Monitorlibrary to query metrics, list metrics definitions and metrics namespaces. [#1409]
- Added Azure Managed Lustre HSM (Hierarchical Storage Management) autoimport and autoexport job management tools:
managedlustre_fs_blob_autoimport_create- Create autoimport jobs to sync data from Azure Blob Storage to Lustre filesystemmanagedlustre_fs_blob_autoimport_get- Get details of specific autoimport job(s)managedlustre_fs_blob_autoimport_cancel- Cancel running autoimport jobsmanagedlustre_fs_blob_autoimport_delete- Delete autoimport job recordsmanagedlustre_fs_blob_autoexport_create- Create autoexport jobs to sync data from Lustre filesystem to Azure Blob Storagemanagedlustre_fs_blob_autoexport_get- Get details of specific autoexport job(s)managedlustre_fs_blob_autoexport_cancel- Cancel running autoexport jobsmanagedlustre_fs_blob_autoexport_delete- Delete autoexport job records
- Added support for listing tables in Azure Storage via command
azmcp_storage_table_list. [#743]
- Added 18 Azure Storage Sync tools for managing cloud synchronization of file shares: [#1419]
- StorageSyncService tools (4): Create, Delete, Get, Update
- RegisteredServer tools (3): Get, Unregister, Update
- SyncGroup tools (3): Create, Delete, Get
- CloudEndpoint tools (4): Create, Delete, Get, TriggerChangeDetection
- ServerEndpoint tools (4): Create, Delete, Get, Update
- Added support for logging to local files using the
--dangerously-write-support-logs-to-diroption for troubleshooting and support scenarios. When enabled, detailed debug-level logs are written to automatically-generated timestamped log files (e.g.,azmcp_20251202_143052.log) in the specified folder. All telemetry is automatically disabled when support logging is enabled to prevent sensitive debug information from being sent to telemetry endpoints. [#1305]
- Fixed a serialization issue in the Foundry Agent File Search tool. [#1205]
- Switched to a new
Azure.Monitor.Query.Logspackage to query logs from Azure Monitor. [#1309] - Replace hard-coded strings for
Azure.Mcp.Serverwith ones fromIConfiguration. [#1269] - Add hardcoded minimum TLS version of 1.2 to Storage account creation tool. [#1445]
- Fixed an issue where the AI Best Practices tool would get called instead of the Best Practices tool. [#1323]
- Removed usage of
writeIndented = true(pretty printing) fromJsonSourceGenerationOptionsto reduce token usage. [#1226] - Updated the .NET 10 SDK version:
10.0.100-preview.7.25380.108→10.0.100. [#1243]
- Added version parameter to the Azure MCP Server registration, which indicates VS code to refresh the tools for the latest MCP server registration. [#1050]
- Fixed elicitation flow to request user confirmation only once for security prompts. Previously, users saw two dialogs (input form + confirmation); now they see a single confirmation dialog (Submit/Cancel) for sensitive operations. [#1225]
- Added a [hidden] command
server_infoto provide server information (name, version) so server metadata is programmatically parsed in telemetry. [#1164] - Added OpenTelemetry tracing support with Azure Monitor exporter for HTTP transport mode, allowing self-hosted instances to export traces to Application Insights when
APPLICATIONINSIGHTS_CONNECTION_STRINGis configured. [#1227]
- We now capture information for the MCP client request's
_metastore. [#1154] - Renamed Microsoft Azure AI Foundry to Microsoft Foundry. [#1211]
- Added version display to CLI help output. The version now appears on the first line when running any help command (e.g.,
azmcp --help). [#1161]
- Improved performance of AI Code generation in Visual Studio 2026 [#1179]
- Updated
AzureAIBestPracticestool to recommendAIProjectClientinstead ofPersistentAgentsClient[#1209]
- Enabled HTTPS redirection by default when running
server start --transport http. This can be opted-out withAZURE_MCP_DANGEROUSLY_DISABLE_HTTPS_REDIRECTIONwhen not needed. [#1169] - Updated the
User-Agentstring to include transport type (stdio or http) for better telemetry and monitoring of Azure service calls. [#1146] - Added support for creating new Redis resources via the
redis_createcommand. [#1093]
- Breaking: Updated
HttpClientServiceto ignore theDefaultUserAgentstring set inHttpClientOptions. [#1146] - Added a
CancellationTokenparameter to async methods to moreI[SomeService]interfaces. [#1178]
- Removed the
DefaultUserAgentconfiguration fromApplicationInsightsSetupthat had a hardcoded version and set theUser-Agentstring for all other service areas that used theHttpClientService. [#1146]
- PostgreSQL MCP tools now support both Microsoft Entra authentication and native database authentication. The default is Entra authentication, users can switch to native database authentication by providing the
--auth-typeparameter with the valuePostgreSQL. If native authentication is selected, the user must also provide the user password via the--passwordparameter. [#1011] - Telemetry: [#1150]
- Enabled telemetry collection for the HTTP transport mode.
- Refactored Azure Monitor exporter configuration to support multiple exporters with separate user-provided and Microsoft telemetry streams.
- Added the
AZURE_MCP_COLLECT_TELEMETRY_MICROSOFTenvironment variable to control Microsoft-specific telemetry collection (enabled by default).
- Added a
CancellationTokenparameter to async methods to moreI[SomeService]interfaces. [#1133]
- PostgreSQL MCP tools has improved the error message reported in case of failure deserializing some of the columns returned by a query. Non out-of-the-box types like
vectorcannot be deserialized and will now report a clear error message indicating which column caused the issue and an action plan so AI agents can recover from it. [#1024] - Fixed exit code when invoking
--helpflag. Commands liketools list --helpnow correctly return exit code0instead of1when successfully displaying help output. [#1118]
- Added an Azure AI Best Practices toolset providing comprehensive guidance for building AI apps with Microsoft Foundry and Microsoft Agent Framework. Includes model selection guidance, SDK recommendations, and implementation patterns for agent development. [#1031]
- Added support for text-to-speech synthesis via the command
speech_tts_synthesize. [#902]
- Breaking: PostgreSQL MCP tools now require SSL and verify the server's full certificate chain before creating database connections. This SSL mode provides both
eavesdropping protectionandman-in-the-middle protection. See SSL Mode VerifyFull for more details. [#1023] - Refactored duplicate elicitation handling code in
CommandFactoryToolLoaderandNamespaceToolLoaderinto a sharedBaseToolLoader.HandleSecretElicitationAsyncmethod. [#1028]
- Updated a codepath
--mode namespacewherelearn=truewouldn't always result in agent learning happening. [#1122] - Use the correct
Assemblyto findVersionfor telemetry. [#1122]
- Added support for speech recognition from an audio file with Fast Transcription via the command
azmcp_speech_stt_recognize. [#1054] - Added support for User-Assigned Managed Identity via the
AZURE_CLIENT_IDenvironment variable. [#1033] - Added the following features for deploying as a
Remote MCP Server:- Added support for HTTP transport, including both incoming and outgoing authentication. Incoming authentication uses Entra ID, while outgoing authentication can either use Entra On-Behalf-Of (OBO) or the authentication configured in the host environment. [#1020]
- Added support for the
--dangerously-disable-http-incoming-authcommand-line option to disable the built-in incoming authentication. Use this option only if you plan to provide your own incoming authentication mechanism, and with caution, as it exposes the server to unauthenticated access. [#1037]
- Enhanced the
tools listcommand with new filtering and output options: [#741]- Added the
--namespaceoption to filter tools by one or more service namespaces (e.g., 'storage', 'keyvault'). - Added the
--name-onlyoption to return only tool names without descriptions or metadata.
- Added the
- Added the following Microsoft Foundry tools: [#945]
foundry_agents_create: Create a new Microsoft Foundry agent.foundry_agents_get-sdk-sample: Get a code sample to interact with a Foundry Agent using the Microsoft Foundry SDK.foundry_threads_create: Create a new Microsoft Foundry Agent Thread.foundry_threads_list: List all Microsoft Foundry Agent Threads.foundry_threads_get-messages: Get messages in a Microsoft Foundry Agent Thread.
- Breaking: Renamed the
--namespacesoption to--namespace-modein thetools listcommand for better clarity when listing top-level service namespaces. [#741] - Telemetry:
- Fixed an issue that spawned child processes per namespace for consolidated mode. [#1002]
- Improved the agent learning experience by ignoring the
commandparameter, which resulted in neither learning nor a tool call to happen. Learning is now always invoked whenlearn=trueis passed. [#1057]
- Initial beta release to validate updated release infrastructure and versioning strategy. No functional changes from 1.x series.
🎉 First Stable Release
We're excited to announce the first stable release of the Azure MCP Server! This milestone represents months of development, extensive testing, and valuable feedback from our community. The Azure MCP Server provides seamless integration between AI agents and 40+ Azure services through the Model Context Protocol (MCP) specification.
The Azure MCP Server now offers:
- Comprehensive Azure Service Coverage: Support for 40+ Azure services including Storage, Key Vault, Cosmos DB, SQL, Kubernetes (AKS), Microsoft Foundry, Event Hubs, Service Bus, PostgreSQL, MySQL, Redis, Azure Monitor, Application Insights, and many more
- Multiple Installation Methods: Available through NuGet, NPM, and Docker; or as an extension/plugin for VS Code, Visual Studio 2022, and IntelliJ IDEA.
- Flexible Server Modes:
- Namespace mode (default): Organizes tools by service for easy discovery
- Consolidated mode: Groups tools by tasks and actions for streamlined workflows
- Single mode: All tools behind one unified "azure" tool
- All mode: Exposes every tool individually for maximum control
- Advanced Authentication: Supports multiple Azure authentication methods with credential chaining
- Production Ready: Includes comprehensive error handling, retry policies, telemetry, and extensive test coverage
- Developer Friendly: Native AOT compilation support, read-only mode for safe exploration, and detailed documentation
- 170+ Azure Commands across Storage, Databases, AI Services, Monitoring, and more
- Enterprise Support: Proxy configuration, managed identity authentication, and secure credential handling
- Performance Optimizations: Selective caching for expensive operations and efficient HTTP client management
Install the Azure MCP Server from your preferred platform:
- VS Code: Install the Azure MCP Server extension
- Visual Studio 2022: Install GitHub Copilot for Azure
- IntelliJ IDEA: Install Azure Toolkit for IntelliJ
- NuGet:
dotnet tool install -g Azure.Mcp --version 1.0.0 - npm:
npx @azure/mcp@1.0.0 - Docker:
docker pull mcr.microsoft.com/azure-mcp:1.0.0
This release wouldn't have been possible without the contributions from our community, extensive testing from early adopters, and collaboration with the MCP ecosystem. Thank you for your feedback, bug reports, and feature requests that helped shape this stable release.
For a complete history of pre-release changes, see versions 0.9.9 through 0.0.10 below.
- Set telemetry fields for
ToolAreaandToolNamewhen "single" mode is used. [#952] - Added instructions on when to not use azd init [#942]
- Adds unique identifier to MCP tools. [#940]
- Set telemetry field's for
ToolAreaandToolNamewhen "consolidated" mode is used or a server is loaded fromregistry.json. [#933]
- Fixed SKU configuration bug in SQL database create and update commands. [#925]
- Fixed a serialization issue with Foundry tools. [#904]
- Improved the following tool namespace descriptions for better LLM tool selection, including usage patterns, messaging scenarios, and when not to use their tools:
- Updated the description of the
azmcp_appservice_database_addcommand to decrease ambiguity and increase selection accuracy by LLMs. [#912]
- Increased Kusto
HttpClienttimeout from 100 seconds to 240 seconds to support long-running queries. [#907] - Provide installation instructions when azd or other registry components are missing. [#926]
- Added instructions to the best practices tool for the GitHub coding agent on how to configure the Azure MCP Server. [#888]
- Added tool name length validation to ensure all tool names stay within 48 character limit for compatibility with MCP clients. [#881]
- Fixed an issue where
azmcp_entra_administrator_listwas not listing administrators correctly. [#891] - Fixed an issue where
azmcp_sql_server_firewall_rule_listwas not listing firewall rules correctly. [#891] - Fixed an issue preventing the
ServerStartedtelemetry event from being published. [#905] - Fixed an issue where MCP tools were missing the 'title' metadata, causing Visual Studio to display raw tool names instead of user-friendly titles. [#898]
- Update the
server.jsonfile in the NuGet distribution to match the2025-09-29schema version (latest from the MCP Registry). [#870]
- Updated how
IsServerCommandInvokedtelemetry is captured to more correctly report whether learning or tool call was performed. [#874]
- Added a new server startup "consolidated" mode, which groups Azure MCP tools by tasks and actions tools conduct. This can be enabled by using the
--consolidatedflag. [#784]
- Removes the
azmcp_prefix from all commands. [#868]
- Updated the description of the following Communications commands to decrease ambiguity and increase selection accuracy by LLMs: [#804]
azmcp_communication_email_sendazmcp_communication_sms_send
- Improved the description of the
--enable-insecure-transportsserver startup option. [#839]
- Fixed a bug where user confirmation (elicitation) stopped working between versions
0.8.5and0.9.2. [#824] - Fixed
IsServerCommandInvokedalways appearing to be true. [#837] - Fixed
ToolNamealways showing up as the tool area even if an MCP tool was invoked. [#837]
- Fixed retained-buffer leaks across services (Kusto, EventGrid, AppLens, Speech, Cosmos, Foundry, NetworkResourceProvider) and tool loaders (BaseToolLoader, ServerToolLoader, NamespaceToolLoader, SingleProxyToolLoader) by disposing
JsonDocument/HttpResponseMessageinstances and cloning returnedJsonElements. (#817)
- Fixed an issue where
azmcp_sql_db_renamewould not work as expected. [#615]
- MCP server start options are now included in telemetry logs. (#794)
- Updated the description of the following Workbook commands to decrease ambiguity and increase selection accuracy by LLMs: [#787]
azmcp_workbook_showazmcp_workbook_update
- Added support for sending an email via Azure Communication Services via the command
azmcp_communication_email_send. [#690] - Added the following Event Hubs commands: [#750]
azmcp_eventhubs_consumergroup_update: Create or update a consumer group for an Event Hub.azmcp_eventhubs_consumergroup_get: Get details of a consumer group for an Event Hubazmcp_eventhubs_consumergroup_delete: Delete a consumer group from an Event Hubazmcp_eventhubs_eventhub_update: Create or update an Event Hub within a namespaceazmcp_eventhubs_eventhub_get: Get details of an Event Hub within a namespaceazmcp_eventhubs_eventhub_delete: Delete an Event Hub from a namespaceazmcp_eventhubs_namespace_update: Create or update an Event Hubs namespaceazmcp_eventhubs_namespace_delete: Delete an existing Event Hubs namespace.
- Added support for listing Microsoft Foundry (Cognitive Services) resources or getting details of a specific one via the command
azmcp_foundry_resource_get. [#762] - Added support for Azure Monitor Web Tests management operations: [#529]
azmcp_monitor_webtests_create: Create a new web test in Azure Monitorazmcp_monitor_webtests_get: Get details for a specific web testazmcp_monitor_webtests_list: List all web tests in a subscription or optionally, within a resource groupazmcp_monitor_webtests_update: Update an existing web test in Azure Monitor
- Added the following Azure CLI commands:
- Added support for Azure AI Search knowledge bases and knowledge sources commands: [#719]
azmcp_search_knowledge_base_list: List knowledge bases defined in an Azure AI Search service.azmcp_search_knowledge_base_retrieve: Execute a retrieval operation using a specified knowledge base with optional multi-turn conversation history.azmcp_search_knowledge_source_list: List knowledge sources defined in an Azure AI Search service.
- Added more deployment related best practices. [#698]
- Added
IsServerCommandInvokedtelemetry field indicating that the MCP tool call resulted in a command invocation. [#751] - Updated the description of the following commands to decrease ambiguity and increase selection accuracy by LLMs:
- Replaced
azmcp_redis_cache_listandazmcp_redis_cluster_listwith a unifiedazmcp_redis_listcommand that lists all Redis resources in a subscription. [#756]- Flattened
azmcp_redis_cache_accesspolicy_listandazmcp_redis_cluster_database_listinto the aforementionedazmcp_redis_listcommand. [#757]
- Flattened
- Fix flow of
Activity.Currentin telemetry service by changingITelemetryService's activity calls to synchronous. [#558]
- Added
--tooloption to start Azure MCP server with only specific tools by name, providing fine-grained control over tool exposure. This option switches server mode to--allautomatically. The--namespaceand--tooloptions cannot be used together. [#685] - Added support for getting ledger entries on Azure Confidential Ledger via the command
azmcp_confidentialledger_entries_get. [#705] - Added support for listing an Azure resource's activity logs via the command
azmcp_monitor_activitylog_list. [#720]
- Unified required parameter validation: null or empty values now always throw
ArgumentExceptionwith an improved message listing all invalid parameters. Previously this would throw eitherArgumentNullExceptionorArgumentExceptiononly for the first invalid value. [#718] - Telemetry:
- Added the following OpenAI commands: [#647]
azmcp_foundry_openai_chat-completions-create: Create interactive chat completions using Azure OpenAI chat models in Microsoft Foundry.azmcp_foundry_openai_embeddings-create: Generate vector embeddings using Azure OpenAI embedding models in Microsoft Foundryazmcp_foundry_openai_models-list: List all available OpenAI models and deployments in an Azure resource.
- Added support for sending SMS messages via Azure Communication Services with the command
azmcp_communication_sms_send. [#473] - Added support for appending tamper-proof ledger entries backed by TEEs and blockchain-style integrity guarantees in Azure Confidential Ledger via the command
azmcp_confidentialledger_entries_append. [#705] - Added the following Azure Managed Lustre commands:
azmcp_azuremanagedlustre_filesystem_subnetsize_validate: Check if the subnet can host the target Azure Managed Lustre SKU and size [#110].azmcp_azuremanagedlustre_filesystem_create: Create an Azure Managed Lustre filesystem. [#50]azmcp_azuremanagedlustre_filesystem_update: Update an Azure Managed Lustre filesystem. [#50]
- Added support for listing all Azure SignalR runtime instances or getting detailed information about a single one via the command
azmcp_signalr_runtime_get. [#83]
- Renamed
azmcp_azuremanagedlustrecommands toazmcp_managedlustre. [#345]- Renamed
azmcp_managedlustre_filesystem_required-subnet-sizetoazmcp_managedlustre_filesystem_subnetsize_ask. [#111]
- Renamed
- Merged the following Azure Kubernetes Service (AKS) tools: [#591]
- Merged
azmcp_aks_cluster_listintoazmcp_aks_cluster_get, which can perform both operations based on whether--clusteris passed. - Merged
azmcp_aks_nodepool_listintoazmcp_aks_nodepool_get, which can perform both operations based on whether--nodepoolis passed.
- Merged
- Updated the description of
azmcp_bicepschema_getto increase selection accuracy by LLMs. [#649] - Update the
ToolNametelemetry field to use the normalized command name when theCommandFactorytool is used. [#716] - Updated the default tool loading behavior to execute namespace tool calls directly instead of spawning separate child processes for each namespace. [#704]
- Improved description of Load Test commands. [#92]
- Fixed an issue where Azure Subscription tools were not available in the default (namespace) server mode. [#634]
- Improved error message for macOS users when interactive browser authentication fails due to broker threading requirements. The error now provides clear guidance to use Azure CLI, Azure PowerShell, or Azure Developer CLI for authentication instead. [#684]
- Added validation for the Cosmos query command
azmcp_cosmos_database_container_item_query. [#524] - Fixed the construction of Azure Resource Graph queries for App Configuration in the
FindAppConfigStoremethod. The name filter is now correctly passed via theadditionalFilterparameter instead oftableName, resolving "ExactlyOneStartingOperatorRequired" and "BadRequest" errors when setting key-value pairs. [#670] - Updated the description of the Monitor tool and corrected the prompt for command
azmcp_monitor_healthmodels_entity_gethealthto ensure that the LLM picks up the correct tool. [#630] - Fixed "BadRequest" error in Azure Container Registry to get a registry, and in EventHubs to get a namespace. [#729]
- Added redundancy in Dockerfile to ensure the azmcp in the Docker image is actually executable. [#732]
- Added support to return metadata when using the
azmcp_tool_listcommand. [#564] - Added support for returning a list of tool namespaces instead of individual tools when using the
azmcp_tool_listcommand with the--namespacesoption. [#496]
- Merged
azmcp_appconfig_kv_listandazmcp_appconfig_kv_showintoazmcp_appconfig_kv_getwhich can handle both listing and filtering key-values and getting a specific key-value. [#505] - Refactored tool implementation to use Azure Resource Graph queries instead of direct ARM API calls:
- Grafana [#628]
- Updated the description of the following commands to increase selection accuracy by LLMs:
- App Deployment:
azmcp_deploy_app_logs_get[#640] - Kusto: [#666]
azmcp_kusto_cluster_getazmcp_kusto_cluster_listazmcp_kusto_database_listazmcp_kusto_queryazmcp_kusto_sampleazmcp_kusto_table_listazmcp_kusto_table_schema
- Redis: [#655]
azmcp_redis_cache_listazmcp_redis_cluster_list
- Service Bus:
azmcp_servicebus_topic_details[#642]
- App Deployment:
- Fixed the name of the Key Vault Managed HSM settings get command from
azmcp_keyvault_admin_gettoazmcp_keyvault_admin_settings_get. [#643] - Removed redundant DI instantiation of MCP server providers, as these are expected to be instantiated by the MCP server discovery mechanism. [#644]
- Fixed App Lens having a runtime error for reflection-based serialization when using native AoT MCP build. [#639]
- Added validation for the PostgreSQL database query command
azmcp_postgres_database_query. [#518]
- Added support for Azure Developer CLI (azd) MCP tools when azd CLI is installed locally - [#566]
- Added support to proxy MCP capabilities when child servers leverage sampling or elicitation. [#581]
- Added support for publishing custom events to Event Grid topics via the command
azmcp_eventgrid_events_publish. [#514] - Added support for generating text completions using deployed Azure OpenAI models in Microsoft Foundry via the command
azmcp_foundry_openai_create-completion. [#54] - Added support for speech recognition from an audio file with Azure AI Services Speech via the command
azmcp_speech_stt_recognize. [#436] - Added support for getting the details of an Azure Event Hubs namespace via the command
azmcp_eventhubs_namespace_get. [#105]
- Refactored Authorization implementation to use Azure Resource Graph queries instead of direct ARM API calls. [#607]
- Refactored AppConfig implementation to use Azure Resource Graph queries instead of direct ARM API calls. [#606]
- Fixed the names of the following MySQL and Postgres commands: [#614]
azmcp_mysql_server_config_config→azmcp_mysql_server_config_getazmcp_mysql_server_param_param→azmcp_mysql_server_param_getazmcp_mysql_table_schema_schema→azmcp_mysql_table_schema_getazmcp_postgres_server_config_config→azmcp_postgres_server_config_getazmcp_postgres_server_param_param→azmcp_postgres_server_param_getazmcp_postgres_table_schema_schema→azmcp_postgres_table_schema_get
- Updated the description of the following commands to increase selection accuracy by LLMs:
- Microsoft Foundry: [#599]
azmcp_foundry_agents_connectazmcp_foundry_models_deployazmcp_foundry_models_deployments_list
- App Lens:
azmcp_applens_resource_diagnose[#556] - Cloud Architect:
azmcp_cloudarchitect_design[#587] - Cosmos DB:
azmcp_cosmos_database_container_item_query[#625] - Event Grid: [#552]
azmcp_eventgrid_subscription_listazmcp_eventgrid_topic_list
- Key Vault: [#608]
azmcp_keyvault_certificate_createazmcp_keyvault_certificate_importazmcp_keyvault_certificate_getazmcp_keyvault_certificate_listazmcp_keyvault_key_createazmcp_keyvault_key_getazmcp_keyvault_key_listazmcp_keyvault_secret_createazmcp_keyvault_secret_getazmcp_keyvault_secret_list
- MySQL: [#614]
azmcp_mysql_server_param_set
- Postgres: [#562]
azmcp_postgres_database_queryazmcp_postgres_server_param_set
- Resource Health: [#588]
azmcp_resourcehealth_availability-status_getazmcp_resourcehealth_service-health-events_list
- SQL: [#594]
azmcp_sql_db_deleteazmcp_sql_db_updateazmcp_sql_server_delete
- Subscriptions:
azmcp_subscription_list[#559]
- Microsoft Foundry: [#599]
- Fixed an issue with the help option (
--help) and enabled it across all commands and command groups. [#583] - Fixed the following issues with Kusto commands:
azmcp_kusto_cluster_listandazmcp_kusto_cluster_getnow accept the correct parameters expected by the service. [#589]azmcp_kusto_table_schemanow returns the correct table schema. [#530]azmcp_kusto_querydoes not fail when the subscription id in the input query is enclosed in double quotes anymore. [#152]- All commands now return enough details in error messages when input parameters are invalid or missing. [#575]
- Fixed
azmcp_subscription_listto return empty enumerable instead ofnullwhen no subscriptions are found. [#508]
- Added support for listing SQL servers in a subscription and resource group via the command
azmcp_sql_server_list. [#503] - Added support for renaming Azure SQL databases within a server while retaining configuration via the
azmcp sql db renamecommand. [#542] - Added support for Azure App Service database management via the command
azmcp_appservice_database_add. [#59] - Added the following Microsoft Foundry agents commands: [#55]
azmcp_foundry_agents_connect: Connect to an agent in a Microsoft Foundry project and query itazmcp_foundry_agents_evaluate: Evaluate a response from an agent by passing query and response inlineazmcp_foundry_agents_query_and_evaluate: Connect to an agent in a Microsoft Foundry project, query it, and evaluate the response in one step
- Enhanced AKS managed cluster information with comprehensive properties. [#490]
- Added support retrieving Key Vault Managed HSM account settings via the command
azmcp-keyvault-admin-settings-get. [#358]
- Refactored Kusto service implementation to use Azure Resource Graph queries instead of direct ARM API calls. [#528]
- Updated
IAreaSetupAPI so the area's command tree is returned rather than modifying an existing object. It's also more DI-testing friendly. [#478] - Updated
CommandFactory.GetServiceAreato check for a tool's service area with or without the rootazmcpprefix. [#478] - Breaking: Removed the following Storage tools: [#500]
azmcp_storage_blob_batch_set-tierazmcp_storage_datalake_directory_createazmcp_storage_datalake_file-system_list-pathsazmcp_storage_queue_message_sendazmcp_storage_share_file_listazmcp_storage_table_list
- Breaking: Updated the
OpenWorldandDestructivehints for all tools. [#510]
- Fixed MCP server hanging on invalid transport arguments. Server now exits gracefully with clear error messages instead of hanging indefinitely. [#511]
- Added the
--insecure-disable-elicitationserver startup switch. When enabled, the server will bypass user confirmation (elicitation) for tools marked as handling secrets and execute them immediately. This is INSECURE and meant only for controlled automation scenarios (e.g., CI or disposable test environments) because it removes a safety barrier that helps prevent accidental disclosure of sensitive data. [#486] - Enhanced Azure authentication with targeted credential selection via the
AZURE_TOKEN_CREDENTIALSenvironment variable: [#56]"dev": Development credentials (Visual Studio → Visual Studio Code → Azure CLI → Azure PowerShell → Azure Developer CLI)"prod": Production credentials (Environment → Workload Identity → Managed Identity)- Specific credential names (e.g.,
"AzureCliCredential"): Target only that credential - Improved Visual Studio Code credential error handling with proper exception wrapping for credential chaining
- Replaced custom
DefaultAzureCredentialimplementation with explicit credential chain for better control and transparency - For more details, see Controlling Authentication Methods with AZURE_TOKEN_CREDENTIALS
- Added support for updating Azure SQL databases via the command
azmcp_sql_db_update. [#488] - Added support for listing Event Grid subscriptions via the command
azmcp_eventgrid_subscription_list. [#364] - Added support for listing Application Insights code optimization recommendations across components via the command
azmcp_applicationinsights_recommendation_list. [#387] - Errata: The following was announced as part of release
0.7.0, but was not actually included then.- Added support for creating and deleting SQL databases via the commands
azmcp_sql_db_createandazmcp_sql_db_delete. [#434]
- Added support for creating and deleting SQL databases via the commands
- Restored support for the following Key Vault commands: [#506]
azmcp_keyvault_key_getazmcp_keyvault_secret_get
- Breaking: Redesigned how conditionally required options are handled. Commands now use explicit option registration via extension methods (
.AsRequired(),.AsOptional()) instead of legacy patterns (UseResourceGroup(),RequireResourceGroup()). [#452] - Breaking: Removed support for the
AZURE_MCP_INCLUDE_PRODUCTION_CREDENTIALSenvironment variable. UseAZURE_TOKEN_CREDENTIALSinstead for more flexible credential selection. For migration details, see Controlling Authentication Methods with AZURE_TOKEN_CREDENTIALS. [#56] - Enhanced AKS nodepool information with comprehensive properties. [#454]
- Merged
azmcp_appconfig_kv_lockandazmcp_appconfig_kv_unlockintoazmcp_appconfig_kv_lock_setwhich can handle locking or unlocking a key-value based on the--lockparameter. [#485] - Update
azmcp_foundry_models_deployto use "GenericResource" for deploying models to Azure AI Services. [#456]
- Added support for diagnosing Azure Resources using the App Lens API via the command
azmcp_applens_resource_diagnose. [#356] - Added support for getting a node pool in an AKS managed cluster via the command
azmcp_aks_nodepool_get. [#394] - Added elicitation support. An elicitation request is sent if the tool annotation
secrethint is true. [#404] - Added
azmcp_sql_server_create,azmcp_sql_server_delete,azmcp_sql_server_showto support SQL server create, delete, and show commands. [#312] - Added the support for getting information about Azure Managed Lustre SKUs via the following command
azmcp_azuremanagedlustre_filesystem_get_sku_info. [#100] azmcp_functionapp_getcan now list Function Apps on a resource group level. [#427]
- Breaking: Merged
azmcp_functionapp_listintoazmcp_functionapp_get, which can perform both operations based on whether--function-appis passed. [#427] - Breaking: Removed Azure CLI (
az) and Azure Developer CLI (azd) extension tools to reduce complexity and focus on native Azure service operations. [#404].
- Marked the
secrethint ofazmcp_keyvault_secret_createtool to "true". [#430]
- The Azure MCP Server is now also available on NuGet.org [#368]
- Added support for listing node pools in an AKS managed cluster. [#360]
- To improve performance, packages now ship with trimmed binaries that have unused code and dependencies removed, resulting in significantly smaller file sizes, faster startup times, and reduced memory footprint. Learn more. [#405]
- Merged
azmcp_search_index_describeandazmcp_search_index_listintoazmcp_search_index_get, which can perform both operations based on whether--indexis passed. [#378] - Merged the following Storage tools: [#376]
azmcp_storage_account_detailsandazmcp_storage_account_listintoazmcp_storage_account_get, which supports the behaviors of both tools based on whether--accountis passed.azmcp_storage_blob_detailsandazmcp_storage_blob_listintoazmcp_storage_blob_get, which supports the behaviors of both tools based on whether--blobis passed.azmcp_storage_blob_container_detailsandazmcp_storage_blob_container_listintoazmcp_storage_blob_container_get, which supports the behaviors of both tools based on whether--containeris passed.
- Updated the descriptions of all Storage tools. [#376]
- Added support for listing all Event Grid topics in a subscription via the command
azmcp_eventgrid_topic_list. [#43] - Added support for retrieving knowledge index schema information in Microsoft Foundry projects via the command
azmcp_foundry_knowledge_index_schema. [#41] - Added support for listing service health events in a subscription via the command
azmcp_resourcehealth_service-health-events_list. [#367]
- Breaking: Updated/removed options for the following commands: [#108]
azmcp_storage_account_create: Removed the ability to configureenable-https-traffic-only(alwaystruenow),allow-blob-public-access(alwaysfalsenow), andkind(alwaysStorageV2now).azmcp_storage_blob_container_create: Removed the ability to configureblob-container-public-access(alwaysfalsenow).azmcp_storage_blob_upload: Removed the ability to configureoverwrite(alwaysfalsenow).
- Added telemetry to log parameter values for the
azmcp_bestpractices_gettool. [#375] - Updated tool annotations. [#377]
- Fixed telemetry bug where "ToolArea" was incorrectly populated with "ToolName". [#346]
- Added
azmcp_sql_server_firewall-rule_createandazmcp_sql_server_firewall-rule_deletecommands. [#121] - Added a verb to the namespace name for bestpractices. [#109]
- Added instructions about consumption plan for azure functions deployment best practices. [#218]
- Fixed a bug in MySQL query validation logic. [#81]
- Fixed VSIX signing [#91]
- Included native packages in build artifacts and pack/release scripts. [#51]
- Fixed a bug with telemetry collection related to AppConfig tools. [#44]
- Updated dependencies to improve .NET Ahead-of-Time (AOT) compilation support:
Microsoft.Azure.Cosmos3.51.0→Microsoft.Azure.Cosmos.Aot0.1.1-preview.1. [#37]
- Added support for listing knowledge indexes in Microsoft Foundry projects via the command
azmcp_foundry_knowledge_index_list. [#1004] - Added support for getting details of an Azure Function App via the
azmcp_functionapp_getcommand. [#970] - Added the following Azure Managed Lustre commands: [#1003]
azmcp_azuremanagedlustre_filesystem_list: List available Azure Managed Lustre filesystems.azmcp_azuremanagedlustre_filesystem_required-subnet-size: Returns the number of IP addresses required for a specific SKU and size of Azure Managed Lustre filesystem.
- Added support for designing Azure Cloud Architecture through guided questions via the
azmcp_cloudarchitect_designcommand. [#890] - Added support for the following Azure MySQL operations: [#855]
azmcp_mysql_database_list- List all databases in a MySQL server.azmcp_mysql_database_query- Execute a SELECT query on a MySQL database (non-destructive only).azmcp_mysql_table_list- List all tables in a MySQL database.azmcp_mysql_table_schema_get- Get the schema of a specific table in a MySQL database.azmcp_mysql_server_config_get- Retrieve the configuration of a MySQL server.azmcp_mysql_server_list- List all MySQL servers in a subscription and resource group.azmcp_mysql_server_param_get- Retrieve a specific parameter of a MySQL server.azmcp_mysql_server_param_set- Set a specific parameter of a MySQL server to a specific value.
- Added telemetry for tracking service area when calling tools. [#1024]
- Standardized Azure Storage command descriptions, option names, and parameter names; cleaned up JSON serialization context. [#1015]
- Breaking: Renamed the following Storage tool option names for consistency:
azmcp_storage_account_create:account-name→account.azmcp_storage_blob_batch_set-tier:blob-names→blobs.
- Breaking: Renamed the following Storage tool option names for consistency:
- Introduced
BaseAzureResourceServiceto enable Azure Resource read operations using Azure Resource Graph queries. [#938] - Refactored SQL service to use Azure Resource Graph instead of direct ARM API calls, removing dependency on
Azure.ResourceManager.Sqland improving startup performance. [#938] - Enhanced
BaseAzureServicewithEscapeKqlStringfor safe KQL query construction across all Azure services; fixed KQL string escaping in Workbooks queries. [#938] - Updated to .NET 10 SDK to prepare for .NET tool packing.
- Improved
bestpracticesandazureterraformbestpracticestool descriptions to work better with VS Code Copilot tool grouping. [#1029]
- SQL service tests now use case-insensitive string comparisons for resource type validation. [#938]
- HttpClient service tests now validate NoProxy collection handling correctly (instead of assuming a single string). [#938]
- Added support for the following Azure Deploy and Azure Quota operations: [#626]
azmcp_deploy_app_logs_get- Get logs from Azure applications deployed using azd.azmcp_deploy_iac_rules_get- Get Infrastructure as Code rules.azmcp_deploy_pipeline_guidance-get- Get guidance for creating CI/CD pipelines to provision Azure resources and deploy applications.azmcp_deploy_plan_get- Generate deployment plans to construct infrastructure and deploy applications on Azure.azmcp_deploy_architecture_diagram-generate- Generate Azure service architecture diagrams based on application topology.azmcp_quota_region_availability-list- List available Azure regions for specific resource types.azmcp_quota_usage_check- Check Azure resource usage and quota information for specific resource types and regions.
- Added support for listing Azure Function Apps via the
azmcp-functionapp-listcommand. [#863] - Added support for importing existing certificates into Azure Key Vault via the
azmcp-keyvault-certificate-importcommand. [#968] - Added support for uploading a local file to an Azure Storage blob via the
azmcp-storage-blob-uploadcommand. [#960] - Added support for the following Azure Service Health operations: [#998]
azmcp-resourcehealth-availability-status-get- Get the availability status for a specific resource.azmcp-resourcehealth-availability-status-list- List availability statuses for all resources in a subscription or resource group.
- Added support for listing repositories in Azure Container Registries via the
azmcp-acr-registry-repository-listcommand. [#983]
- Improved guidance for LLM interactions with Azure MCP server by adding rules around bestpractices tool calling to server instructions. [#1007]
- New VS Code settings to control Azure MCP server startup behavior: [#971]
azureMcp.serverMode: choose tool exposure mode —single|namespace(default) |all.azureMcp.readOnly: start the server in read-only mode.azureMcp.enabledServices: added drop down list to select and configure the enabled services.
- Added support for listing Azure Function Apps via the
azmcp-functionapp-listcommand. [#863] - Added support for getting details about an Azure Storage Account via the
azmcp-storage-account-detailscommand. [#934]
- Centralized handling and validation of the
--resource-groupoption across all commands. [#961]
- Added support for listing Azure Container Registry (ACR) registries in a subscription via the
azmcp-acr-registry-listcommand. [#915] - Added new Azure Storage commands:
- Bundled the GitHub Copilot for Azure extension as part of the Azure MCP Server extension pack.
- The
azmcp-storage-account-listcommand now returns account metadata objects instead of plain strings. Each item includes:name,location,kind,skuName,skuTier,hnsEnabled,allowBlobPublicAccess,enableHttpsTrafficOnly. Update scripts to read thenameproperty. The underlyingIStorageService.GetStorageAccounts()signature changed fromTask<List<string>>toTask<List<StorageAccountInfo>>. [#904] - Consolidated "AzSubscriptionGuid" telemetry logic into
McpRuntime. [#935]
- Fixed best practices tool invocation failure when passing "all" action with "general" or "azurefunctions" resources. [#757]
- Updated metadata for CREATE and SET tools to
destructive = true. [#773]
- Improved Azure MCP display name in VS Code from 'azure-mcp-server-ext' to 'Azure MCP' for better user experience in the Configure Tools interface. [#871, #876]
- Updated the description of the following
CommandGroups to improve their tool usage by Agents:
- Fixed subscription parameter handling across all Azure MCP service methods to consistently use
subscriptioninstead ofsubscriptionId, enabling proper support for both subscription IDs and subscription names. [#877] - Fixed
ToolExecutedtelemetry activity being created twice. [#741]
- Added support for providing the
--content-typeand--tagsproperties to theazmcp-appconfig-kv-setcommand. [#459] - Added
filter-pathandrecursivecapabilities toazmcp-storage-datalake-file-system-list-paths. [#770] - Added support for listing files and directories in Azure File Shares via the
azmcp-storage-share-file-listcommand. This command recursively lists all items in a specified file share directory with metadata including size, last modified date, and content type. [#793] - Added support for Azure Virtual Desktop with new commands: [#653]
azmcp-virtualdesktop-hostpool-list- List all host pools in a subscriptionazmcp-virtualdesktop-sessionhost-list- List all session hosts in a host poolazmcp-virtualdesktop-sessionhost-usersession-list- List all user sessions on a specific session host
- Added support for creating and publishing DevDeviceId in telemetry. [#810]
- Added caching for Cosmos DB databases and containers. [#813]
- Parameter Name Changes: Removed unnecessary "-name" suffixes from command parameters across 25+ parameters in 12+ Azure service areas to improve consistency and usability. Users will need to update their command-line usage and scripts. [#853]
- AppConfig:
--account-name→--account - Search:
--service-name→--service,--index-name→--index - Cosmos:
--account-name→--account,--database-name→--database,--container-name→--container - Kusto:
--cluster-name→--cluster,--database-name→--database,--table-name→--table - AKS:
--cluster-name→--cluster - Postgres:
--user-name→--user - ServiceBus:
--queue-name→--queue,--topic-name→--topic - Storage:
--account-name→--account,--container-name→--container,--table-name→--table,--file-system-name→--file-system,--tier-name→--tier - Monitor:
--table-name→--table,--model→--health-model,--resource-name→--resource - Foundry:
--deployment-name→--deployment,--publisher-name→--publisher,--license-name→--license,--sku-name→--sku,--azure-ai-services-name→--azure-ai-services
- AppConfig:
- Fixed an issue where the
azmcp-storage-blob-batch-set-tiercommand did not correctly handle the--tierparameter when setting the access tier for multiple blobs. [#808]
- Added support for batch setting access tier for multiple Azure Storage blobs via the
azmcp-storage-blob-batch-set-tiercommand. This command efficiently changes the storage tier (Hot, Cool, Archive, etc) for multiple blobs simultaneously in a single operation. [#735] - Added descriptions to all Azure MCP command groups to improve discoverability and usability when running the server with
--mode singleor--mode namespace. [#791]
- Removed toast notifications related to Azure MCP server registration and startup instructions.[#785]
- Removed
--partner-tenant-idoption fromazmcp-marketplace-product-getcommand. [#656]
- Added support for listing SQL databases via the command:
azmcp-sql-db-list. [#746] - Added support for reading
AZURE_SUBSCRIPTION_IDfrom the environment variables if a subscription is not provided. [#533]
- Initial Release