gpt4 book ai didi

c# - IIS7 进程回收后,两台服务器之间的 WCF 通信崩溃

转载 作者:太空狗 更新时间:2023-10-30 01:27:52 24 4
gpt4 key购买 nike

我有点被这个问题难住了,希望我能在这里找到一些答案。

基本上,我有一个跨 2 个服务器运行的 ASP.NET 应用程序。服务器 A 将所有业务逻辑/数据访问公开为 Web 服务,服务器 B 拥有与这些服务对话的网站(通过 WCF,使用 net.tcp 绑定(bind))。

问题发生在服务器 A 上的 IIS 启动我的应用程序池回收几秒钟后。回收发生在分配的时间之后(使用 IIS 中设置的默认 29 小时)。

在(服务器 A 的)服务器日志中:

A worker process with process id of '####' serving application pool 'AppPoolName' has requested a recycle because the worker process reached its allowed processing time limit.

我认为这是正常行为。问题是几秒钟后,我在服务器 B 上收到此异常:

This channel can no longer be used to send messages as the output session was auto-closed due to a server-initiated shutdown. Either disable auto-close by setting the DispatchRuntime.AutomaticInputSessionShutdown to false, or consider modifying the shutdown protocol with the remote server.

并不是每次回收都会发生这种情况;我假设当有人在回收发生时通过请求访问网站时会发生这种情况。

此外,在我进行干预之前,我的应用程序一直处于关闭状态;每次对该页面发出后续请求时,此异常都会继续发生。我通过编辑 web.config(通过在文件末尾添加一个空格或一些无害的东西)并保存它来进行干预——我认为这会导致我的应用程序重新编译并恢复服务。我还尝试运行一个批处理文件,每次发生异常时它都会为我执行此操作;)

现在,我几乎找不到关于这个异常的任何信息,而且我一直在寻找一段时间。我找到的大部分信息都与我没有使用的 WCF 设置有关。

我已经阅读了“DispatchRuntime.AutomaticInputSessionShutdown”,我认为它不属于这种情况。这个特定的属性指的是服务响应客户端的行为而自动关闭,这不是这里发生的事情。此处,服务因 IIS 而关闭。

我读过 this它通过某种变通来自动恢复服务,但我真的很想了解这里发生了什么,而不是绕过它!

我已经开始尝试 IIS7 中的设置,特别是打开/关闭重叠回收并增加进程启动/关闭时间。我想知道完全关闭回收是否安全(我相信如果我将回收时间间隔设置为 0?)但是我又想知道发生了什么!

无论如何,如果您需要更多信息,请告诉我。提前致谢!

最佳答案

这可能与您打开和关闭 WCF 连接的方式有关。

如果您在应用程序启动时打开代理,然后继续使用它,则连接中断,这是由服务器端重启引起的。导致客户端出错,因为代理正在与之通信的服务器不再存在。

当您重新启动客户端(更改 web.config)时,会针对正在运行的服务器创建新代理。

解决此问题的方法是确保在使用后关闭 WCF 连接。

http://www.codeguru.com/csharp/.net/net_wcf/article.php/c15941/

关于c# - IIS7 进程回收后,两台服务器之间的 WCF 通信崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2123911/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com