我有一个客户端应用程序,它使用非托管dll与服务器通信。
所有与网络相关的操作都在非托管dll中进行。 在对服务器进行多次操作之后,客户端的TCP端口不足。 如果我们使用'netstat -an'检查netwotk的状态,我们得到以下结果:
...
TCP 192.168.11.55:56048 192.168.10.28:5000 FIN_WAIT_2
TCP 192.168.11.55:56049 192.168.10.28:5000 FIN_WAIT_2
TCP 192.168.11.55:56050 192.168.10.28:5000 FIN_WAIT_2
TCP 192.168.11.55:56051 192.168.10.27:5000 FIN_WAIT_2
TCP 192.168.11.55:56052 192.168.10.28:5000 FIN_WAIT_2
TCP 192.168.11.55:56053 192.168.10.27:5000 FIN_WAIT_2
TCP 192.168.11.55:56054 192.168.10.27:5000 FIN_WAIT_2
TCP 192.168.11.55:56055 192.168.10.27:5000 FIN_WAIT_2
TCP 192.168.11.55:56056 192.168.10.27:5000 FIN_WAIT_2
TCP 192.168.11.55:56057 192.168.10.28:5000 FIN_WAIT_2
TCP 192.168.11.55:56058 192.168.10.27:5000 FIN_WAIT_2
TCP 192.168.11.55:56059 192.168.10.28:5000 FIN_WAIT_2
TCP 192.168.11.55:56060 192.168.10.27:5000 FIN_WAIT_2
...
只有在客户端关闭后才会释放端口。
如果我在调试模式下运行VS项目,它永远不会耗尽端口。 但是,在发布模式下运行时,它正在发生。
我既无法访问服务器也无法访问客户端。
如何释放或终止处于FIN_WAIT_2状态的端口?
答案 0 :(得分:8)
当套接字在FIN_WAIT_2中时,本地套接字已关闭,正在等待远程套接字发送其关闭请求。如果此关闭请求永远不会到达,则套接字将保持FIN_WAIT_2状态一段时间。
这背后的原因是,如果来自远程方的关闭请求将被延迟并在另一个应用程序重新使用套接字后到达,则该新连接将立即关闭。
如果需要,可以更改超时,但最终非托管dll尚未完全实现TCP关闭序列。有关更多信息,请参阅
答案 1 :(得分:1)
关闭/关闭客户端套接字时,服务器端套接字将读取0 bytes
此时,您应该关闭/关闭服务器套接字。您的连接将显示为TIME_WAIT
PID0
并最终消失。
我认为这一切都很好。