Why are my Application Insights logs not being ingested from Azure Function App?
I recently updated my C# based Azure Functions App to use the Application Insights SDK instead of just passing the APPINSIGHTS_INSTRUMENTATIONKEY. The logs work perfectly when I run the app on my development machine using func start
but when I deploy it to Azure Functions nothing ends up in the logs. When I run union traces, exceptions, requests, dependencies, customMetrics
I only see log messages sent from my laptop.
However, I'm able to see the log messages sent from Azure Functions in Live Metrics. After about an hour of waiting, I also see these trace messages:
AI: Diagnostic message: backoff logic disabled, transmission will be resolved.
AI: Diagnostic message: backoff logic was enabled. Backoff internal exceeded 40.6 min. Last status code received from the backend was 999.
The Function App is in a VNET but doesn't have any firewall enabled. The Network Security Group allows outbound access to anywhere. The services are all deployed in the Sweden Central location. The ingestion endpoint (swedencentral-0.in.applicationinsights.azure.com) resolves and responds to tcpping on port 443.
My test application writes a log row per each log level from Trace to Critical. None of the rows appear in the Log Analytics workspace but everything from Warning upwards shows up in the Live Metrics as well as the Log Stream.
I tried to troubleshoot the network connectivity by opening up a Kudu PowerShell on the Function App but the Invoke-WebRequest doesn't work for any address I've tried. I tried with different TLS versions but they all give the same error:
PS C:\home> [Net.ServicePointManager]::SecurityProtocol
[Net.ServicePointManager]::SecurityProtocol
Tls12
PS C:\home> Invoke-WebRequest 'https://google.com'
Invoke-WebRequest 'https://google.com'
Invoke-WebRequest : The underlying connection was closed: An unexpected error occurred on a send.
At line:1 char:1
+ Invoke-WebRequest 'https://google.com'
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (System.Net.HttpWebRequest:HttpWebRequest) [Invoke-WebRequest], WebException
+ FullyQualifiedErrorId : WebCmdletWebResponseException,Microsoft.PowerShell.Commands.InvokeWebRequestCommand
What else could I try? I've already deleted and redeployed all the related resources.