我有一个Windows服务 - 当它启动时 - 打开一些WCF服务来监听8000端口.碰巧这项服务有时会崩溃.如果是这样,TCP连接不会被释放,因此如果我尝试再次启动它,会导致我的服务抛出异常:
AddressAlreadyInUseException:IP端点0.0.0.0:8000上已有一个侦听器
一些观察:
当运行CurrPorts或者netstat -ano
,我可以看到8000端口仍然在使用(在LISTENING
状态),并通过进程ID拥有XXX
这相当于我的服务进程ID.但我的服务已经崩溃,并且不再出现在任务管理器中.因此,我无法杀死释放端口的过程!当然,运行taskkill /PID XXX
返回:
错误:找不到"XXX"进程.
运行CurrPorts或者netstat -b
,我可以看到创建监听端口所涉及的进程名称是System
,而不是MyService.exe
(因为它是MyService.exe
我的服务运行时).
我试图使用CurrPorts关闭连接,但我总是收到以下错误消息:
无法关闭一个或多个TCP连接.请注意,您必须以管理员身份运行此工具才能关闭TCP连接.
(不用说,我以管理员身份运行CurrPorts ......)
TCPView也没有太大帮助:与8000端口关联的进程名称是
,并且执行"结束进程"或"关闭连接"无效.
我尝试XXX
使用Process Explorer查看是否没有与PID关联的子进程,但这里没有运气.
如果我正确关闭服务(崩溃之前),则正确释放TCP连接.这是正常的,因为我在服务时关闭了WCF服务主机OnStop()
.
我发现释放连接的唯一方法是重新启动服务器(这在生产环境中不方便,你可以猜到).等待没有帮助,TCP连接永远不会释放.
如何在不重新启动Windows服务器的情况下关闭连接?
PS:发现了一些 与我非常相似的问题.