解决WCF“这可能是由于服务终结点绑定未使用 HTTP 协议造成的,这还可能是由于服务器中止了 HTTP 请求上下文(可能由于服务关闭)所致”异常

时间:2015-01-20 01:07:46   收藏:0   阅读:5770

      最近对系统的架构进行优化,用WinForm模拟客户端调用WCF,在WCF起一个Bus,把接收到的消息推送到各个Sub端。

   本来很简单的调用关系,结果把WCF服务部署到IIS后,一直报“接收对 http://lenovo-y460:8099/Service.svc 的 HTTP 响应时发生错误。这可能是由于服务终结点绑定未使用 HTTP 协议造成的。这还可能是由于服务器中止了 HTTP 请求上下文(可能由于服务关闭)所致。有关详细信息,请参见服务器日志。”异常,效果如下图所示:

   技术分享

   出异常了,用控制变量法对异常进行排除。

   排除过程如下:

    1.用WCF调试状态下的客户端调用ESB的Publish方法调用成功,证明ESB的推送是没有问题的;

   2.用WinForm调用部署在IIS上的WCF的测试方法(不包含bus.Publish方法)调用成功,证明WCF服务是没有问题的;

   3.用WinForm调用部署在IIS上的WCF的bus.Publish方法调用失败,报上述异常;

   4.用WinForm调用WCF调试状态下的bus.Publish方法调用成功。

   最终得出结果(度娘说是什么类没有序列化,狠狠的把我坑了):很可能是IIS的原因。

   既然WinForm可以调用WCF调试状态下的WSDL地址,为什么不能调用WCF部署在IIS上的WSDL地址?很可能是因为IIS的权限不够,解决方案如下:

   IIS管理器-->应用程序池-->选中目标应用池-->高级设置-->进程模型-->标识-->自定义账户-->设置-->输入本机Administrator级别的用户名、密码,配置如下:

   技术分享

   这个Bug调了3天,今天终于解决了,很有成就感。

   希望我的讲解能帮助大家进步。

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!