AspNetCore.Docs/aspnetcore/azure/devops/monitoring.md

8.2 KiB

title author description ms.author ms.custom ms.date uid
DevOps with ASP.NET Core and Azure | Monitor and debug CamSoper A guide that provides end-to-end guidance on building a DevOps pipeline for an ASP.NET Core app hosted in Azure. casoper mvc 10/24/2018 azure/devops/monitor

Monitor and debug

Having deployed the app and built a DevOps pipeline, it's important to understand how to monitor and troubleshoot the app.

In this section, you'll complete the following tasks:

  • Find basic monitoring and troubleshooting data in the Azure portal
  • Learn how Azure Monitor provides a deeper look at metrics across all Azure services
  • Connect the web app with Application Insights for app profiling
  • Turn on logging and learn where to download logs
  • Stream logs in real time
  • Learn where to set up alerts
  • Learn about remote debugging Azure App Service web apps.

Basic monitoring and troubleshooting

App Service web apps are easily monitored in real time. The Azure portal renders metrics in easy-to-understand charts and graphs.

  1. Open the Azure portal, and then navigate to the mywebapp<unique_number> App Service.

  2. The Overview tab displays useful "at-a-glance" information, including graphs displaying recent metrics.

    Overview panel

    • Http 5xx: Count of server-side errors, usually exceptions in ASP.NET Core code.
    • Data In: Data ingress coming into your web app.
    • Data Out: Data egress from your web app to clients.
    • Requests: Count of HTTP requests.
    • Average Response Time: Average time for the web app to respond to HTTP requests.

    Several self-service tools for troubleshooting and optimization are also found on this page.

    Self-service tools

    • Diagnose and solve problems is a self-service troubleshooter.
    • Application Insights is for profiling performance and app behavior, and is discussed later in this section.
    • App Service Advisor makes recommendations to tune your app experience.

Advanced monitoring

Azure Monitor is the centralized service for monitoring all metrics and setting alerts across Azure services. Within Azure Monitor, administrators can granularly track performance and identify trends. Each Azure service offers its own set of metrics to Azure Monitor.

Profile with Application Insights

Application Insights is an Azure service for analyzing the performance and stability of web apps and how users use them. The data from Application Insights is broader and deeper than that of Azure Monitor. The data can provide developers and administrators with key information for improving apps. Application Insights can be added to an Azure App Service resource without code changes.

  1. Open the Azure portal, and then navigate to the mywebapp<unique_number> App Service.

  2. From the Overview tab, click the Application Insights tile.

    Application Insights tile

  3. Select the Create new resource radio button. Use the default resource name, and select the location for the Application Insights resource. The location doesn't need to match that of your web app.

    Application Insights setup

  4. For Runtime/Framework, select ASP.NET Core. Accept the default settings.

  5. Select OK. If prompted to confirm, select Continue.

  6. After the resource has been created, click the name of Application Insights resource to navigate directly to the Application Insights page.

    New Application Insights resource is ready

As the app is used, data accumulates. Select Refresh to reload the blade with new data.

Application Insights overview tab

Application Insights provides useful server-side information with no additional configuration. To get the most value from Application Insights, instrument your app with the Application Insights SDK. When properly configured, the service provides end-to-end monitoring across the web server and browser, including client-side performance. For more information, see the Application Insights documentation.

Logging

Web server and app logs are disabled by default in Azure App Service. Enable the logs with the following steps:

  1. Open the Azure portal, and navigate to the mywebapp<unique_number> App Service.

  2. In the menu to the left, scroll down to the Monitoring section. Select Diagnostics logs.

    Diagnostic logs link

  3. Turn on Application Logging (Filesystem). If prompted, click the box to install the extensions to enable app logging in the web app.

  4. Set Web server logging to File System.

  5. Enter the Retention Period in days. For example, 30.

  6. Click Save.

ASP.NET Core and web server (App Service) logs are generated for the web app. They can be downloaded using the FTP/FTPS information displayed. The password is the same as the deployment credentials created earlier in this guide. The logs can be streamed directly to your local machine with PowerShell or Azure CLI. Logs can also be viewed in Application Insights.

Log streaming

App and web server logs can be streamed in real time through the portal.

  1. Open the Azure portal, and navigate to the mywebapp<unique_number> App Service.

  2. In the menu to the left, scroll down to the Monitoring section and select Log stream.

    Log stream link

Logs can also be streamed via Azure CLI or Azure PowerShell, including through the Cloud Shell.

Alerts

Azure Monitor also provides real time alerts based on metrics, administrative events, and other criteria.

Note: Currently alerting on web app metrics is only available in the Alerts (classic) service.

The Alerts (classic) service can be found in Azure Monitor or under the Monitoring section of the App Service settings.

Alerts (classic) link

Live debugging

Azure App Service can be debugged remotely with Visual Studio when logs don't provide enough information. However, remote debugging requires the app to be compiled with debug symbols. Debugging shouldn't be done in production, except as a last resort.

Conclusion

In this section, you completed the following tasks:

  • Find basic monitoring and troubleshooting data in the Azure portal
  • Learn how Azure Monitor provides a deeper look at metrics across all Azure services
  • Connect the web app with Application Insights for app profiling
  • Turn on logging and learn where to download logs
  • Stream logs in real time
  • Learn where to set up alerts
  • Learn about remote debugging Azure App Service web apps.

Additional reading