Until yesterday, IntelliTrace in production environment was not supported, so the usefulness of it was a bit argued.
But now with Visual Studio 11, we can collect IntelliTrace logs from production environment in a completely supported way! And moreover, if you ask the Microsoft CSS (Customer Support Service) for help, the first question would be: “May you send me the IntelliTrace log please?”
Before of configuring IntelliTrace logs collection, we have to set security for the IIS Application pool account:
icacls sitepath “IIS APPPOOL\<AppPool Account>”:(F)
data:image/s3,"s3://crabby-images/8ca7b/8ca7b2cab20182589d4901deb1884b42207f5650" alt="image image"
Then, hands on the bits. Suppose we have a web application throwing an exception.
Firstly, we have to deploy IntelliTrace to the target environment. Pretty easy, just extract content from the IntelliTraceCollection.cab file you can find under the C:\Program Files (x86)\Microsoft Visual Studio 11.0\Common7\IDE\CommonExtensions\Microsoft\IntelliTrace\11.0.0 path.
Then we have to extract it to the target server. I suggest using the expand command from a command prompt:
expand.exe /f:* IntelliTraceCollection.cab path
Lastly, bring up PowerShell:
data:image/s3,"s3://crabby-images/4b6ce/4b6cecf6e15a377e9f2afc3337480256c14933d7" alt="image image"
We have to load the IntelliTrace PowerShell Module:
Import-Module sitepath\Microsoft.VisualStudio.IntelliTrace.PowerShell.dll
After doing so, we can get the full list of commands we can use:
Get-Command *IntelliTrace*
data:image/s3,"s3://crabby-images/a9c82/a9c82ac1f64822aa7e83334eade5f0cbea4f4539" alt="image image"
And now we collect logs about the target application:
Start-IntelliTraceCollection ApplicationPool CollectionPath OutputPath
CollectionPath is the path we chose for IntelliTrace. In there, there are two “profiles”: collection_plan.ASP.NET.default.xml which collects only IntelliTrace events, and collection_plan.ASP.NET.trace.xml, which traces also function calls and events.
OutputPath is where we store logs.
data:image/s3,"s3://crabby-images/4ab2f/4ab2f12ea9db73444d17033c1ad91b2d2e2d83b0" alt="image image"
After deciding Yes (to all
) we have to run the application.
When we got the error, we have to snapshot the log file:
Checkpoint-IntelliTraceCollection ApplicationPool
data:image/s3,"s3://crabby-images/722e9/722e98304ad5d646937f0a2904a8460379e539cf" alt="image image"
And then we have to stop collecting it.
Stop-IntelliTraceCollection ApplicationPool
data:image/s3,"s3://crabby-images/53c1d/53c1d2348c030a7e154b84c698da597155cec931" alt="image image"
That’s all: we have the logs.
To analyse them, it’s just a classic IntelliTrace analysis as we always did.