开发者

Does a single web request to IIS stay on a single thread?

I want to write a logging http module that stores a list of log events for a single request in thread local storage while the request executes. On End_Request I want to write all the events back to persistent storage.

Question is, will one request match to one thread? I.e. can I assume from anywhere in my code that I can add items to the IEnumerable and they will properly be all tog开发者_如何学Goether at the end of the request.


No. ASP.NET can potentially switch threads while processing a request. This is known as thread-agility.

There are only certain points where it can/will do this. I can't remember what they are off the top of my head - searching for a reference now...

But the short answer is NO: you can't rely on the same thread-local storage being accessible for the entire duration of the request.


You might be better off using Context.Items rather than thread storage - that's per request. You don't need to worry about what the server is doing with its threads that way.


The session remains constant for the duration of the request. Why not use that?


I would look at maybe using ELMAH and or log4net to get what you need done as it is simple to use and now even simpler to install using NuGet package manager.

http://code.google.com/p/elmah/

http://logging.apache.org/log4net/

Sometimes it's great to use code that is already tested and configured for the environment you need rather than rolling your own, but hey that's your call.


If you are prepared to potentially lose the log data you have accumulated then you could wait until the end of the request to write to the log, irrespective of thread safety. If it's important to you that every event be logged then I would suggest that you write events to the log as they occur rather.

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜