Skip to content

Latest commit

 

History

History
40 lines (26 loc) · 2.8 KB

Challenge-07.md

File metadata and controls

40 lines (26 loc) · 2.8 KB

Challenge 07 - Monitoring

< Previous Challenge - Home - Next Challenge >

Introduction

Application Insights can be integrated with Azure Function Apps to provide robust monitoring for your functions. In this challenge, you will provision a new centralized Application Insights account and configure all of your Function Apps to send telemetry to it.

Description

  1. Create an Application Insights resource
    • Name : Similar to TollboothMonitor
    • Hint : Copy the instrumentation key
  2. Add application insights to your "App" function app and "Events" function app
    • Name: APPINSIGHTS_INSTRUMENTATIONKEY
  3. Open the Live Metrics Stream for the app insights in the "App" function app (may take a few minutes for App Insights to appear)
  4. Open the /UploadImages folder and execute dotnet build and then dotnet run "<yourBlobConnectionString>" with the blobStorageConnection string as an argument, between quotes. Press 1, then enter in the console to upload a few images.

NOTE Check the /UploadImages/Program.cs file and review the two folder paths in the Directory.GetFiles() method (line 124 and 131).

  1. Go back to the portal to view the telemetry. You should start seeing new telemetry arrive, showing the number of servers online, the incoming request rate, CPU process amount, etc. You can select some of the sample telemetry in the list to the side to view output data.
  2. Leave the Live Metrics Stream window open once again, and close the console window for the image upload. Re-run the UploadImages project, but this time press 2, then ENTER in the console. This will upload 1,000 new photos.
  3. Switch back to the Live Metrics Stream window and observe the activity as the photos are uploaded. It is possible that the process will run so efficiently that no more than two servers will be allocated at a time. You should also notice things such as a steady cadence for the Request Rate monitor, the Request Duration hovering below ~500ms second, and the Process CPU percentage roughly matching the Request Rate.
  4. Close the console window when done.

Success Criteria

  1. You have been able to successfully monitor the execution of the functions in Application Insights.

Learning Resources

Advanced Challenges

Too comfortable? Eager to do more? Try these additional challenges!