c#-通过多个长时间运行的操作优化ASMX Web服务

我正在使用具有DoLookup()函数的C#编写ASP.NET Web服务.对于对DoLookup()函数的每次调用,我都需要我的代码来执行两个单独的查询:一个查询到远程站点上的另一个Web服务,另一个查询到本地数据库.在我可以编译结果并将它们作为对DoLookup方法的响应之前,必须完成两个查询.我要解决的问题是,无论是响应时间还是Web服务器上的资源使用情况,我都想使其尽可能高效.我们期望每小时最多数千个查询.这是到目前为止我所掌握的类似于C#的大致概述:

public class SomeService : System.Web.Services.WebService
{
    public SomeResponse DoLookup()
    {
        // Do the lookup at the remote web service and get the response 
        WebResponse wr = RemoteProvider.DoRemoteLookup();   

        // Do the lookup at the local database and get the response
        DBResponse dbr = DoDatabaseLookup();

        SomeResponse resp = new SomeResponse( wr, dbr);

        return resp;
    }
}

上面的代码按顺序执行所有操作,并且效果很好,但是现在我想使其更具可伸缩性.我知道可以异步调用DoRemoteLookup()函数(RemoteProvider具有BeginRemoteLookup / EndRemoteLookup方法),也可以使用BeginExecuteNonQuery / EndExecuteNonQuery方法异步进行数据库查找.

我的问题(最后)是:如何在单独的线程上同时触发远程Web服务查找和数据库查找,并确保它们都已完成,然后返回响应?

我想在单独的线程上执行两个请求的原因是,它们都可能具有较长的响应时间(1或2秒),并且我想释放Web服务器的资源以在等待响应时处理其他请求.还有一点需要注意的是-我确实有当前异步运行的远程Web服务查找,我只是不想让上面的示例过于混乱.我正在努力的是同时启动远程服务查找和数据库查找,并弄清它们何时都完成.

感谢您的任何建议.

解决方法:

您可以使用一对AutoResetEvent,每个线程一个.在线程执行结束时,您调用AutoResetEvents.Set()来触发事件.

生成线程后,可以将WaitAll()与两个AutoResetEvents一起使用.这将导致线程阻塞,直到同时设置了两个事件.

这种方法的警告是,必须确保Set()被确保被调用,否则将永远阻塞.此外,请确保使用线程来执行适当的异常处理,否则,当未处理的异常导致您的Web应用程序重新启动时,您会无意中引起更多的性能问题.

MSDN Has sample code regarding AutoResetEvent usage.

上一篇:在Python中设计多进程蜘蛛


下一篇:java-假设Spring MessageSource实现是线程安全的吗?