AI Skill
Official
Review
Audit score 70

azure-upgrade

microsoft/azure-skills

Assess and upgrade Azure workloads between plans, tiers, SKUs, or modernize Azure SDK dependencies in source code.

What is azure-upgrade?

azure-upgrade is a skill for coding agents that guides assessment and automated migration of Azure workloads from one service, hosting plan, or SKU to another — entirely within Azure. It covers Azure Functions plan upgrades (Consumption to Flex Consumption), App Service to Container Apps migrations, Azure Cache for Redis (ACR/ACRE) to Azure Managed Redis (AMR), and Java SDK source-code modernization (com.microsoft.azure to com.azure). The skill follows a structured phase-by-phase workflow, uses Azure MCP tools for documentation and best practices, requires user confirmation before destructive actions, and tracks progress in a workspace file.

  • Upgrades Azure Functions from Consumption plan to Flex Consumption plan
  • Migrates Azure Cache for Redis (ACR/OSS Basic/Standard/Premium) to Azure Managed Redis (AMR)
  • Migrates Azure Cache for Redis Enterprise (ACRE/Enterprise Flash) to Azure Managed Redis (AMR)
  • Modernizes legacy Java Azure SDK dependencies (com.microsoft.azure.* to com.azure.*)
  • Assesses upgrade readiness before executing any changes
  • Generates idempotent, resumable automation scripts and tracks progress in upgrade-status.md

How to install azure-upgrade

npx skills add https://github.com/microsoft/azure-skills --skill azure-upgrade
Prerequisites
  • Azure MCP server available with tools: mcp_azure_mcp_get_azure_bestpractices, mcp_azure_mcp_documentation, mcp_azure_mcp_appservice, mcp_azure_mcp_applicationinsights
  • Access to the Azure subscription containing the source workload
  • For Java SDK migration: Java project source code accessible in the workspace
  • For Redis migration: existing ACR, ACRE, or OSS Redis cache details
  • Coding agent compatible with SKILL.md packages (e.g. Claude Code, Cursor)
Claude Code
Cursor
Windsurf
Cline

How to use azure-upgrade

  1. 1.Install the skill with: npx skills add https://github.com/microsoft/azure-skills --skill azure-upgrade
  2. 2.Describe your upgrade intent to the agent (e.g. 'Upgrade my function app from Consumption to Flex Consumption')
  3. 3.The agent identifies the source and target plan/SKU and asks you to confirm
  4. 4.The agent runs an assessment of your existing workload for upgrade readiness
  5. 5.Review the assessment, then confirm the target plan or SKU before any changes are made
  6. 6.The agent executes the upgrade steps, migrating settings, identities, and deploying code
  7. 7.Validate the upgraded workload by confirming the app is reachable and monitoring is active
  8. 8.Optionally hand off to azure-validate for deep validation or azure-deploy for CI/CD setup

Use cases

Good for
  • Upgrading a function app from Consumption to Flex Consumption for better scaling
  • Migrating a Premium Redis cache to Azure Managed Redis with SKU selection guidance
  • Modernizing a Java project that uses legacy com.microsoft.azure SDK packages
  • Changing the hosting plan or SKU of an existing Azure Functions app
  • Assessing whether an existing workload is ready for a target Azure plan or tier
Who it's for
  • Java developers maintaining apps with legacy Azure SDK dependencies
  • Cloud engineers managing Azure Functions workloads needing plan upgrades
  • Platform teams migrating Redis caches to Azure Managed Redis
  • Developers looking to automate Azure service tier or SKU changes
  • Teams preparing Azure workloads for modernization within Azure

azure-upgrade FAQ

Does this skill support cross-cloud migrations (e.g. AWS to Azure)?

No. This skill is only for upgrades within Azure. For cross-cloud migrations, use the azure-cloud-migrate skill instead.

Will the skill delete my original app automatically?

No. The skill will never delete or stop the original app without explicit user confirmation. Destructive actions always require approval.

How does Java SDK modernization differ from service/plan upgrades?

Java SDK migration runs a source-code modernization flow that rewrites com.microsoft.azure.* dependencies to com.azure.*, and follows a separate reference path rather than the standard upgrade steps.

What happens if my upgrade scenario is not listed?

The skill uses the mcp_azure_mcp_documentation and mcp_azure_mcp_get_azure_bestpractices tools to research the upgrade path for unlisted scenarios.

Where is upgrade progress tracked?

Progress is tracked in an upgrade-status.md file created in the workspace root during the upgrade process.

Full instructions (SKILL.md)

Source of truth, from microsoft/azure-skills.


name: azure-upgrade description: "Assess and upgrade Azure workloads between plans, tiers, or SKUs, or modernize Azure SDK dependencies in source code. WHEN: upgrade Consumption to Flex Consumption, upgrade Azure Functions plan, change hosting plan, function app SKU, migrate App Service to Container Apps, modernize legacy Azure Java SDKs (com.microsoft.azure to com.azure), migrate Azure Cache for Redis (ACR/ACRE) to Azure Managed Redis (AMR)." license: MIT compatibility: python3.10+ metadata: author: Microsoft version: "1.1.4"

Azure Upgrade

This skill handles assessment and automated upgrades of existing Azure workloads from one Azure service, hosting plan, or SKU to another — all within Azure. This includes plan/tier upgrades (e.g. Consumption → Flex Consumption), cross-service migrations (e.g. App Service → Container Apps), and SKU changes. It also covers Azure SDK for Java source-code modernization (e.g. legacy Java com.microsoft.azure.* → modern com.azure.*). This is NOT for cross-cloud migration — use azure-cloud-migrate for that.

Triggers

User IntentExample Prompts
Upgrade Azure Functions plan"Upgrade my function app from Consumption to Flex Consumption"
Change hosting tier"Move my function app to a better plan"
Assess upgrade readiness"Is my function app ready for Flex Consumption?"
Automate plan migration"Automate the steps to upgrade my Functions plan"
Modernize legacy Azure Java SDK"Migrate legacy Azure SDKs for Java", "Upgrade legacy Azure Java SDK", "Migrate my Java project from com.microsoft.azure to com.azure"
Migrate Azure Cache for Redis (ACR/OSS) to Azure Managed Redis (AMR)"Migrate my Redis cache to AMR", "ACR to AMR", "OSS to AMR", "Upgrade my Premium P2 cache to Managed Redis", "Pick an AMR SKU", "Convert my Redis IaC template to AMR"
Migrate Azure Cache for Redis Enterprise (ACRE) to Azure Managed Redis (AMR)"Migrate my Enterprise_E10 cache to AMR", "ACRE to AMR", "Update my ACRE IaC template for AMR", "Migrate EnterpriseFlash to AMR", "Migrate my geo-replicated Enterprise Redis"

Rules

  1. Follow phases sequentially — do not skip
  2. Generate an assessment before any upgrade operations
  3. Load the scenario reference and follow its rules
  4. Use mcp_azure_mcp_get_azure_bestpractices and mcp_azure_mcp_documentation MCP tools
  5. Destructive actions require ask_userglobal-rules
  6. Always confirm the target plan/SKU with the user before proceeding
  7. Never delete or stop the original app without explicit user confirmation
  8. All automation scripts must be idempotent and resumable

Upgrade Scenarios

SourceTargetReference
Azure Functions Consumption PlanAzure Functions Flex Consumption Planconsumption-to-flex.md
Legacy Azure Java SDK (com.microsoft.azure.*)Modern Azure Java SDK (com.azure.*)languages/java/README.md
Azure Cache for Redis (ACR/OSS) Basic/Standard/PremiumAzure Managed Redis (AMR)services/redis/redis-to-amr.md
Azure Cache for Redis Enterprise (ACRE) / Enterprise FlashAzure Managed Redis (AMR)services/redis/redis-to-amr.md

SDK upgrade scenarios (e.g. Java legacy → modern) run a source-code modernization flow that is distinct from Azure service/plan/SKU upgrades: follow the scenario reference, not the Steps below.

No matching scenario? Use mcp_azure_mcp_documentation and mcp_azure_mcp_get_azure_bestpractices tools to research the upgrade path.

MCP Tools

ToolPurpose
mcp_azure_mcp_get_azure_bestpracticesGet Azure best practices for the target service
mcp_azure_mcp_documentationLook up Azure documentation for upgrade scenarios
mcp_azure_mcp_appserviceQuery App Service and Functions plan details
mcp_azure_mcp_applicationinsightsVerify monitoring configuration

Steps

  1. Identify — Determine the source and target Azure plans/SKUs. Ask user to confirm.
  2. Assess — Analyze existing app for upgrade readiness → load scenario reference (e.g., consumption-to-flex.md)
  3. Pre-migrate — Collect settings, identities, configs from the existing app
  4. Upgrade — Execute the automated upgrade steps (create new resources, migrate settings, deploy code)
  5. Validate — Hit the function app default URL to confirm the app is reachable, then verify endpoints and monitoring
  6. Ask User — "Upgrade complete. Would you like to verify performance, clean up the old app, or update your IaC?"
  7. Hand off to azure-validate for deep validation or azure-deploy for CI/CD setup

Track progress in upgrade-status.md inside the workspace root.

References

Next

After upgrade is validated, hand off to:

  • azure-validate — for thorough post-upgrade validation
  • azure-deploy — if the user wants to set up CI/CD for the new app