Rollback Strategies in Azure DevOps

Rollback strategies in Azure DevOps help you respond quickly to deployment failures, ensuring your application remains stable by restoring a previous working version.


What Are Rollback Strategies?

Rollback strategies allow teams to recover from bad deployments. Whether it's a broken feature or a failed release, rollbacks give you a safety net to restore a previous version without significant downtime.

  • Minimize disruption to users by reverting changes quickly
  • Support both manual and automated rollback mechanisms
  • Ensure production stability during risky deployments
  • Integrate directly into your CI/CD pipelines

Types of Rollback Strategies

  • Manual Rollback: Redeploy a known good version from artifact history when needed
  • Automated Rollback: Configure pipelines to detect failures and revert automatically
  • Blue-Green Deployment: Maintain two environments (live and idle) and switch traffic upon failure
  • Canary Deployment: Release to a small group first, then roll out gradually if no issues arise

How to Configure Rollbacks in Azure DevOps

To enable effective rollbacks, follow these best practices:

  1. Keep versioned build artifacts: Ensure every deployment package is archived and retrievable
  2. Use deployment slots: Deploy to staging slots and swap only when verified
  3. Define rollback conditions: Use pipeline logic to detect failed deployments and take action
  4. Document rollback steps: Especially for critical systems that require manual intervention
  5. Test rollback regularly: Validate rollback steps during QA or staging phases

Sample YAML for an Automated Rollback


stages:
- stage: Deploy
  displayName: 'Deploy to Production'
  jobs:
  - deployment: DeployWebApp
    environment: 'Production'
    strategy:
      runOnce:
        deploy:
          steps:
          - task: AzureWebApp@1
            inputs:
              azureSubscription: 'AzureServiceConnection'
              appName: 'my-web-app'
              package: '$(Pipeline.Workspace)/drop/*.zip'

          - task: PowerShell@2
            inputs:
              script: |
                if ($LastExitCode -ne 0) {
                    Write-Host "Deployment failed! Rolling back..."
                    az webapp deployment slot swap --resource-group myResourceGroup --name my-web-app --slot staging
                }
        

This example assumes you're using deployment slots and triggers a rollback if the deployment fails.

Best Practices for Rollbacks

  • Use deployment slots to swap back instantly if needed
  • Set up alerts and monitoring to detect deployment issues
  • Maintain artifact history for all successful builds
  • Test rollback scenarios before going live with new features
  • Leverage feature flags to toggle features without code changes

Conclusion

Rollback strategies are a vital part of any mature DevOps process. Whether you're deploying to test environments or production, having a rollback plan ensures confidence and resilience when something goes wrong.

Coming up next: you'll explore how to use Infrastructure as Code (IaC) with Azure DevOps to automate provisioning and improve environment consistency.