究竟如何AsyncController
避免使用 ASP.NET 工作线程?如果我使用基于事件的模式(伪代码):
[AsyncTimeout(60000)]
public void WaitForWakeUp()
{
AsyncManager.OutstandingOperations.Increase();
EventRaisedElsewhere +=
state =>
{
AsyncManager.OutstandingOperations.Decrease();
return Content("Woke up because of " + state);
};
}
...然后根据Clay Lenharts的说法,它不使用 ASP.NET 工作线程。这怎么可能?
我看了一点AsyncController
源代码,但什么都不懂,除了它使用了IAsyncResult
很多并且QueueUserWorkItem
在某些地方确实如此。
但是如何使用BeginInvoke
和QueueUserWorkItem
不使用 ASP.NET 工作线程呢?当然这两个都使用线程池线程,并且肯定在 ASP.NET 工作进程中只有一个线程池?
根据 MSDN,
Web 服务器从线程池中获取一个线程(工作线程)并调度它来处理传入的请求。该工作线程启动异步操作。
工作线程返回到线程池以服务另一个 Web 请求。
当异步操作完成时,它会通知 ASP.NET。
但是对于任何重要的事情,听起来启动异步操作仍然需要一个线程来运行。只有在极其简单的情况下(例如使用 BCL 下载 Web 内容)才会完全展开和/或完全 IOCP 绑定,对吗?
我之所以这样问,部分原因是我看到所有这些聊天服务器都是使用实现的AsyncController
,如果他们所做的只是“等待新消息”,我不明白如何在非线程池线程上完成。