It is very familiar. “XXX works fine locally but does not work at all in production”.
I am going to take assumption that the environment variable, ASPNETCORE_ENVIRONMENT, will be used to determine whether the application is running in Development mode or Production mode. Setting it as “Development.
data:image/s3,"s3://crabby-images/b1a2f/b1a2f3989b841a976d09959329a7ee50ffa9947b" alt=""
Next move to Azure App services.
Within Azure Portal, add ASPNETCORE_ENVIRONMENT to the Application settings. Instead of “Development”, we will use “Production” here. Navigate to the App Service for the application, then navigate to Configuration:
data:image/s3,"s3://crabby-images/05583/055835f3a86ca2ecccb232c5493dda0565b96f04" alt=""
Turn on App Service Logs to Filesystem in App Service
Within Azure Portal, navigate to App Service logs, Turn on Web server logging. This creates the folder path “D:\home\LogFiles\http\RawLogs” and starts writing server log files there.
data:image/s3,"s3://crabby-images/5f038/5f0381896dbb63f4f1b4087d196f7566038c46a8" alt=""
A few benefits of us writing Serilog rolling files in the same location:
1-One single spot to access logs
2-When Application Logging (Filesystem) is turned on, you can view the Serilog logs in the Log Stream under App Service Monitoring section as well! Awesome!
data:image/s3,"s3://crabby-images/f90f7/f90f74447565fc5dd6638225178abc6f7a06217c" alt=""
Test and view the log files
Assuming your app service URL is https://YourWebAppName.azurewebsites.net, while being logged into Azure Portal, visit https://YourWebAppName.SCM.azurewebsites.net which is the Kudu site. You should be able to locate the log files by going to Debug console/CMD and navigate to “D:\home\LogFiles\http\RawLogs”.
Another spot to diagnose the problem is to look here;
data:image/s3,"s3://crabby-images/8917b/8917b07b4653479b6ce7f51e16abd10492da069a" alt=""
And on the next page, look here;
data:image/s3,"s3://crabby-images/22bce/22bce99a55d9baf263ba96aef8709c436a342f2f" alt=""
It is easy to develop and test locally but when you deploy the application to Azure App Service, a few extra steps are required so that logs are properly populated and accessible within the Azure App Service.
Resources
data:image/s3,"s3://crabby-images/22373/22373bbe742fa77d1315d32273d1236353c01e58" alt="Favorite Favorite"
data:image/s3,"s3://crabby-images/9f222/9f2227a31cd5b72ff84b5213bcf5174bc0c4fdd9" alt="Loading Loading"