Skip to content

Latest commit

 

History

History
141 lines (107 loc) · 9.46 KB

2-azd-init.md

File metadata and controls

141 lines (107 loc) · 9.46 KB

Workshop: Azd init

Introduction

Azure Developer CLI (azd) is an open-source tool that accelerates the time it takes for you to get your application from local development environment to Azure. azd provides best practice, developer-friendly commands that map to key stages in your workflow, whether you’re working in the terminal, your editor or integrated development environment (IDE), or CI/CD (continuous integration/continuous deployment). You can use azd with extensible blueprint templates that include everything you need to get an application up and running on Azure. These templates include reusable infrastructure as code assets and proof-of-concept application code that can be replaced with your own app code. You can also create your own template or find one to build upon.

  • azure.yaml - A metadata that is used to configure Azure resources for deployment.

Learning Objectives

  1. Leveraging azd to accelerates the time it takes for you to get your application from development environment to Azure.

Challenges

  1. Bootstrapping and provisioning an initial template for your Azure environment.
  2. Test and monitor your new Todo application.
  3. Grant services data plane access to run and debug the ToDo application locally.
  4. Configure CI/CD using Github Actions.

Challenge 1: Bootstrapping and provisioning an initial template for your Azure environment

  1. Provision cloud resources:
    1. Open new terminal: Menu -> Terminal -> New Terminal (or Ctrl + Shift + ~).

    2. Execute azd auth login to authenticate Azure Developer CLI with your Azure Account, and use --use-device-code to authenticate from inside the devcontainer:

      azd auth login --use-device-code
    3. Provision Azure Resources:

      1. Run the azd up command:

        azd up
        
      2. Pick a new environment name in the following format tt-<your-alias>-dev-<location> (for example tt-amhollan-dev-eus2), where location is a short name representing the location where resources will be be provisioned.

        Location Short Name
        eastus2 eus2
        eastus eus
        westeurope weu
        centralus cus
      3. Once you are signed-in to Azure, you will be prompted for the following information:

        Parameter Description
        Azure Location The Azure location where your resources will be deployed.
        Azure Subscription The Azure Subscription where your resources will be deployed.

      After you provide these values, the azd up command:

      • Creates and configures all necessary Azure resources (azd provision), including:
        • Access policies and roles for your account
        • Service-to-service communication with Managed Identities
      • Packages and deploys the code (azd deploy)
      • Create a new environment under .azure directory and set it as the default environment
      • Refresh environment settings and state that will be populated while provisioning azure resources via main.parameters.json file.

      Note: This might take a few minutes and you can monitor the progress in the terminal, or in Azure Portal via the link under Provisioning Azure resources step.

      azd up

Challenge 2: Test and monitor your new Todo application

After provisioning your Azure resources, you can test and monitor your new ToDo application is up and running.

  1. Locate the Web UI endpoint via the terminal output or run azd show command:

    # Showing deployed endpoints and environments for apps in this directory.
    azd show
    
    # Showing deployed specific app endpoint
    azd show | grep "web" | awk '{print $2}'
    
  2. Open the Web UI endpoint in your browser.

  3. Create new ToDo lists and items at least three for each, in order to simulate some traffic to the application.

  4. Use azd monitor command whose parameters launch various Application Insights dashboards. Run any of the following commands in the terminal to monitor your application health:

    Application Insights dashboard Command
    Main dashboard azd monitor --overview
    Live metrics dashboard azd monitor --live
    Logs dashboard azd monitor --logs

Challenge 3: Grant services data plane access to run and debug the ToDo application locally

In order to run and debug the ToDo application, you will require data plane access. The template is already configured with the required resources, but you will need to provide your user principal and reprovision the resources.

  1. Update azd environment with your user principal id:

    # Retrieve your user object id from Azure Entra ID
    objectId=$(az ad signed-in-user show --query id -o tsv)
    
    azd env set AZURE_PRINCIPAL_ID $objectId
    

    Note: this will update your azd environment under .azure/<environmentName>/.env file and will be populated while provisioning azure resources via main.parameters.json file.

  2. Reprovision cloud resources:

    azd provision
    

Challenge 4 (Optional): Configure CI/CD using Github Actions

Prerequisite: The following challenge requires a GitHub account.

CI/CD stands for Continuous Integration/Continuous Delivery. It is a software development practice that aims to automate the building, testing, and deployment of code changes. CI/CD helps developers deliver high-quality software faster and more reliably.

GitHub Actions is a feature of GitHub that allows you to create and run workflows for your repository. Workflows are composed of jobs, which are individual steps that can run commands, scripts, or actions. Actions are reusable pieces of code that can perform tasks such as installing dependencies, running tests, or deploying applications. You can use actions from the GitHub Marketplace or create your own.

To use GitHub Actions for CI/CD, you need to create a YAML file in your repository under the .github/workflows directory. This file defines the triggers, jobs, and actions for your workflow. For example, you can trigger a workflow when you push code to a branch, open a pull request, or create a release. You can also specify the environment, secrets, and artifacts for your workflow.

The course content based on azd template that already contains a Github Action workflow file under .github/workflows/azure-dev.yml. This workflow file is configured to run on every push to the main branch and will execute the following steps:

  1. To configure the workflow, you need to give GitHub permission to deploy to Azure on your behalf. Authorize GitHub by creating an Azure service principal stored in a GitHub secret named AZURE_CREDENTIALS.

    azd pipeline config --provider github
  2. Supply the requested GitHub information.

  3. When prompted about committing and pushing your local changes to start a new GitHub Actions run, specify y.

  4. In the terminal window, view the results of the azd pipeline config command. The azd pipeline config command will output the GitHub repository name for your project. azd pipeline config

  5. Using your browser, open the GitHub repository for your project.

  6. Select Actions tab to see the workflow running.

    Note: In case your repository is forked from the original repository the workflow won't be running, and you will need to enable GitHub Actions Workflow first. Once you enabled the workflow you will be able to trigger it manually, and make sure you are selecting your branch and not the main branch.

  7. Validate workflow run status is green. Github Actions

Additional Resources

Name Description
Azure Developer CLI Azure Developer CLI (azd) documentation
Github Marketplace GitHub Marketplace provides a curated collection of tools, applications, and services that can be integrated seamlessly with GitHub repositories.
Github - Azure authentication Set up Azure Login with OpenID Connect authentication