运维开发网

如何在Linux中终止单个TCP连接?

运维开发网 https://www.qedev.com 2020-03-03 14:27 出处:网络
我有一个进程,可以在不同的端口上打开几个tcp连接到多个浏览器. 使用netsat输出是这样的:
我有一个进程,可以在不同的端口上打开几个tcp连接到多个浏览器.

使用netsat输出是这样的:

tcp 0 0 server1.something:myprog client1.something:49987 ESTABLISHED
tcp 0 0 server1.something:myprog client1.something:65987 ESTABLISHED
tcp 0 0 server1.something:myprog client1.something:89987 ESTABLISHED

现在我想杀死其中一个连接?我该怎么做? (因为杀死进程会杀死所有连接)

以下是一些选项:

>使用gdb附加并在fd上调用close().您可以使用ls -la / proc / $pid / fd从addr / port到inode编号通过/ proc / net / tcp和inode编号映射到进程内的FD.

>欺骗RST数据包.你需要在本地生成它并以某种方式猜测SEQ号.

>也许设置一个iptables规则来生成下一个数据包的RST.

>编写内核模块.

似乎没有一个很好的支持方式来做到这一点.如果他们的FD无论如何意外关闭,那么进程很可能会崩溃.

0

精彩评论

暂无评论...
验证码 换一张
取 消