最近使用WCF做的一个程序也是过段时间调用就出现异常,异常信息如下:
System.ServiceModel.CommunicationException: 套接字连接已中止。这可能是由于处理消息时出错或远程主机超过接收超时或者潜在的网络资源问题导致的。本地套接字超时是“00:01:00”。 ---> System.IO.IOException: 写操作失败,请参见内部异常。 ---> System.ServiceModel.CommunicationException: 套接字连接已中止。这可能是由于处理消息时出错或远程主机超过接收超时或者潜在的网络资源问题导致的。本地套接字超时是“00:01:00”。 ---> System.Net.Sockets.SocketException: 远程主机强迫关闭了一个现有的连接。
经上网搜索,下面的文章可能解决我的问题,至于出现的原因未知。目前也没有时间核实。
以下内容转载:
+++++++++++++++++++++++++++++++++++++
(使用Windows Service作为宿主的时候也会出现这样的情况,搜索的) 我们这里是自定义托管宿主,在进行WCF编程开发过程时,使用NetTcpBinding绑定协议,作为通讯协议,可能会引发这样的异常,导致数据如法传输。套接字连接中断,可能是由于消息处理错误,或者远程宿主接受超时引起,或者是底层网络资源问题导致,本地套接字时间是'00:00:59.7656250'。具体信息如下:
The socket connection was aborted. This could be caused by an error processing your message or a receive timeout being exceeded by the remote host, or an underlying network resource issue. Local socket timeout was '00:00:59.7656250'.
此问题的的解决办法:
我查询了很多资料,国外论坛也有人已经遇到这样的问题。
1.http://social.msdn.microsoft.com/forums/en-US/wcf/thread/637e6097-9161-40ee-8578-46388b7647cd
2.http://social.msdn.microsoft.com/forums/en-US/wcf/thread/06cb1522-31f0-4ce3-85f0-02656228a8e1/
这个是两个MSDN上讨论的解决办法,更换其他的绑定协议确实可以解决问题。
参考代码如下:
WSHttpBinding binding = new WSHttpBinding();
binding.ReceiveTimeout = new TimeSpan(10, 10, 10);
我测试的结果使用basicHttpBinding协议也可以,不会出现这样的异常。
原始地址:http://tech.ddvip.com/2009-06/1245068271123970.html
+++++++++++++++++++++++++++++++++++++