Your ToDo application is deployed, real-time event streaming is happenning, and all good! or not. Customers started to complains about latency and downtime... It’s time to monitor and scale your application!
Overtime you might suffer from performance issues when the application is under load or when you add more and more features. Current implementation uses same compute (App Service Plan) for three different applications (Web, API, Backend), Cosmos DB, Storage, APIM, and more resources, maybe you are lack of resources, maybe we need to scale.
When you start to investigate the application using Application map in Application Insights, you can see that the system suffers and we need to figure out what's going on.
To understand the root cause of the problem, you can use Failures and Operations views in Application Insights and confirm the issue is related to all applications, which hints that maybe the compute resource is the bottleneck.
- Monitor and troubleshoot your application using Azure Monitor and Application Insights.
- Scale your application to meet the demand.
- Scale App Service Plan.
- Configure health check probe for App Service instance.
- Use health checks for dependencies in your application.
- Open main.bicep file and locate appServicePlan resource.
- Change the sku name property from B1 to B3. B3 is a higher tier that will provide more compute resources X4 vCPU and ~X6 Memory (GB) for the applications.
- Provision changes using
azd provision
command:azd provision
- Validate we mitigated the issue by checking the Application map and Failures views in Application Insights, where we expect to see no more downtime and failures on requests.
Since we had no indication about the healthiness of our applications, we were emberresed when our customers started to complain. We need to avoid such cases in the future, and make sure we get an alert when something is wrong with our application. Health check increases your application's availability by rerouting requests away from unhealthy instances and replacing instances if they remain unhealthy. It does that by pinging every minute a path of your web application of your choice.
We can configure a health check probe for our application, and configure an alert to notify us when the application is unhealthy.
- Open backend.bicep file and add
healthCheckPath: '/api/healthz'
to the function app resource. This will leverage App Service Plan health check probe to check the health of our application in intervals by calling to the/api/healthz
endpoint and expecting to get 200 OK response.module backend '../core/host/functions.bicep' = { name: '${serviceName}-functions-dotnet-module' dependsOn: [ storage ] params: { name: name location: location tags: union(tags, { 'azd-service-name': serviceName }) allowedOrigins: allowedOrigins alwaysOn: true appSettings: appSettings applicationInsightsName: applicationInsightsName appServicePlanId: appServicePlanId keyVaultName: keyVaultName runtimeName: 'dotnet' runtimeVersion: '6.0' storageAccountName: storage.outputs.name scmDoBuildDuringDeployment: false healthCheckPath: '/api/healthz' } }
- Provision changes using
azd provision
command:azd provision
- Go to the function app resource in the Azure Portal and validate function is healthy:
Azure Function Health is small library based on the aspnetcore HealthChecks feature. The traditional health checks registered in an aspnetcore API included the HealthCheckPublisherHostedService as a HostedService which is not possible or desired to run in an Azure Function. However there are benefits to included a health check in an Azure Function to test the depencies of your service. This library will allow you to register health checks for your dependencies and create an HTTP endpoint that can be used to monitor the health of your application.
There are a number of health checks that you can add to your Function App that have already been implemented. You can add any of the healthcheck defined here.
- Add Microsoft.Extensions.Diagnostics.HealthCheck nuget package.
dotnet add package Microsoft.Extensions.Diagnostics.HealthChecks --version 6.0.25
- In your Startup.cs class register your health checks
builder.Services .AddHealthChecks() .AddAzureCosmosDB();
Name | Description |
---|---|
Monitor App Service instances using Health check | https://learn.microsoft.com/en-us/azure/app-service/monitor-instances-health-check?tabs=dotnet |