dotnet-podcasts/docs/demos/azurecontainerapps
Marcus Felling afa90d3c9b
use Azure Bicep
2022-09-17 11:37:33 -05:00
..
MessageCount.ps1 Remove accept header 2021-12-03 11:03:26 +01:00
Readme.md use Azure Bicep 2022-09-17 11:37:33 -05:00
Simulate-Feed-Requests.ps1 Initial commit 2021-11-29 11:54:48 -08:00
feeds.json Initial commit 2021-11-29 11:54:48 -08:00
scale-out-demo-0.png Initial commit 2021-11-29 11:54:48 -08:00
scale-out-demo-1.png Initial commit 2021-11-29 11:54:48 -08:00
scale-out-demo-2.png Initial commit 2021-11-29 11:54:48 -08:00

Readme.md

Azure Container Apps

This folder contains additional scripts needed for testing the Azure Container Apps scenario.

You must first enable the feeds injestion API by turning it on in the api.bicep file on line 64.

"deployIngestion": true

Demo steps:

  1. Get the HTTP API application details:

    az containerapp show -g "$RESOURCE_GROUP_NAME" -n podcastapi
    
  2. Look for the application's address in the fqdn field in the ingress config section:

    "configuration": {
        "ingress": {
        "external": true,
        "fqdn": "<FQDN>",
        "targetPort": 80,
        "transport": "auto"
        },
    
  3. Browse the HTTP API to confirm It works.

    https://<FQDN>
    
  4. Open a PowerShell terminal and watch Container Apps:

  • podcastingestionca: Worker service that scale based on queue messages. When the queue is empty the container app should have 1 instances.

    scale: {
        maxReplicas: 5
        minReplicas: 1
        rules: [
          {
            name: 'queue-scaling-rule'
            azureQueue: {
              queueName: 'feed-queue'
              queueLength: 20
              auth: [
                {
                  secretRef: 'feedqueue'
                  triggerParameter: 'connection'
                }
              ]
            }
          }
        ]
      }
    
  • podcastapica: HTTP API that scale based on concurrent HTTP requests. When there are no incoming requests the container app should have 0 instances.

    scale: {
       minReplicas: 0
       maxReplicas: 5
       rules: [
         {
           name: 'httpscalingrule'
           http: {
             metadata: {
               concurrentRequests: '20'
             }
           }
         }
       ]
     }
    

    4.1 Run this commands to watch container apps scaling out.

    while (1) { 
        $output = az containerapp revision list -n podcastapica -g dotnetconf2021-netpodcast --query "[?properties.active].{Name:properties.name, CreatedTime:properties.createdTime, Active:properties.active, Replicas:properties.replicas}" -o table --only-show-errors
        clear;
        echo $output;
        sleep 2;
    }
    
    while (1) { 
        $output = az containerapp revision list -n podcastingestionca -g dotnetconf2021-netpodcast --query "[?properties.active].{Name:properties.name, CreatedTime:properties.createdTime, Active:properties.active, Replicas:properties.replicas}" -o table --only-show-errors
        clear;
        echo $output;
        sleep 2;
    }
    
        while (1) { 
        $output = ./MessageCount.ps1 -storageAccount <storageAccountName> -accessKey <accessKey>
        clear;
        echo $output;
        sleep 1;
    }
    

    Initial replicas

  1. Simulate some load sending POST requests to the HTTP API. You should see new messages appearing in the Azure Storage Queue. (feed-queue).

    ./Simulate-Feed-Requests.ps1 -baseUrl https://<FQDN>/
    

    Queue messages

  2. Observe how the HTTP API and the worker scale out.

    Scale out replicas