ASP.NET服务器端多线程设计——异步Web Service

在上一章介绍过异步IHttpHandler后,大家应该了解到异步操作带来的好处。它可以及时释放服务器线程池里面的线程,当完成外部操作再使用回调函数进行数据获取。

下面为大家介绍一下异步Web Service的操作,其实它与异步IHttpHandler的原理是十分相似的,记得在介绍IHttpHandler里面以Stream异步作为例子,下面以SqlCommand作为例子。(还说一句老话,我这里指的是服务器端的异步方式,而并非客户端异步调用)

[ISerializable]

public class User{....}

public class Service1:System.Web.Service.WebSerivce

{

      //系统会自动识别BeginMethod(参数,AsyncCallback,object),EndMethod(IAsyncResult)方法

      //并把它作为异步方法处理

      [WebMethod]
  public IAsyncResult BeginGetList(int age,  AsyncCallback cb, object o)

     {          

           SqlConnection conn = new SqlConnection("Data Source=...;...;Asynchronous Processing=true");

           string commandString="Select * From User as t1 Where t1.age>"+age.ToString();
           SqlCommand command = new SqlCommand(commandString, conn);
           conn.Open();
           return this.m_cmd.BeginExecuteRead(cb, command);

           //此时,服务器的线程会被释放,等待Command完成时Callback唤醒

      }

  [WebMethod]
  public List<User> EndGetList(IAsyncResult result)

      {

            Sqlcommand command=(SqlCommand) result.AsyncState;    

            SqlDataRead read=command.EndExecuteRead(result);

            ............  //数据转换

            return users;

      }

}

在客户端调用的时候,由于信息是通过SOAP方便传递,系统可以自动识别GetList(int age)方法。你也可以在客户端使用异步调用的方式,来调用WebService,这样可以使系统配合得更完美。

可惜的是,微软还没有一个完美的异步ADO.NET调用机制;而只是将 SQL 调用包装到异步委托调用中对提高效率没有什么帮助。

个人建议可以尝试使用 Microsoft SQL Server  Web Services Toolkit将您的数据库发布为 Web 服务。

 

总结:

ASP.NET Web 服务中提供了一个有效的机制,可以异步调用后端服务,使线程池中的宝贵线程及时得到释放。通过结合对后端资源的异步请求,服务器可以使用自己的 Web 方法使同时处理的请求数目达到最大。您应该考虑使用此方法开发高性能的 Web 服务应用程序。

 

ASP.NET服务器端多线程设计——异步Web服务

ASP.NET服务器端多线程设计——异步IHttpHandler

 

对 JAVA 开发有兴趣的朋友欢迎加入QQ群:174850571 共同探讨!
对 .NET  开发有兴趣的朋友欢迎加入QQ群:162338858 共同探讨 !

posted on 2011-01-15 12:05  风尘浪子  阅读(2594)  评论(0编辑  收藏  举报

导航