Linux 下怎么释放 TCP 连接

2015-04-30 12:35:25 +08:00
 gameliving
主要是路由器版adbyby有bug,进程死了后不清除tcp连接,导致路由器上开了上千TCP连接。。。导致其它设备不能进行TCP连接
6309 次点击
所在节点    Linux
9 条回复
datocp
2015-04-30 13:05:01 +08:00
刚查了一下这东西有点像privoxy这样的代理软件来过滤广告。所以既然代理进程挂了那只能去判断重启进程。不然后续连接肯定有问题。

tcp udp连接dd tt都有参数可以直接调整内核idle timeout,但是做过qos的效果更明显。只能用脚本去侦测ip并发数再去实施iptables limit或者tcp reset之类。显然你的不属于tcp timeout的问题更像是进程不再响应后续连接。
gameliving
2015-04-30 13:53:10 +08:00
@datocp 经过测试,大概6小时左右会影响到网速,如果让路由器每6小时释放一次TCP应该怎么弄?
ryd994
2015-04-30 14:18:18 +08:00
照理说,进程结束后,所有未关闭的文件句柄会由父进程接手,最后由init释放。
tcp sock也是文件句柄。
是服务死了但进程还在么?
还是父进程没处理?
datocp
2015-04-30 14:23:35 +08:00
http://www.groad.net/bbs/thread-8832-1-1.html
没用过adbyby看看这介绍吧。
iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-ports 8118
有这样的语句存在进程崩溃,当然后续连接无法代理了。所以应该研究的是如何用cron配合shell脚本进行进程守候处理。
gameliving
2015-04-30 14:54:50 +08:00
@ryd994 adbyby会弄出来好几十个子进程。。。。
ryd994
2015-04-30 15:00:53 +08:00
@gameliving 按4楼的做法,kill父进程,可以温和一点,SIGTERM
几十个子进程不是问题,问题是父进程没有帮子进程释放资源。
这时候只能kill父进程,让init处理

@datocp cron每分钟加一条iptables规则这算几个意思?
gameliving
2015-04-30 17:40:44 +08:00
@ryd994 @datocp
刚才试了一下,killall adbyby只能释放极少一部分TCP连接
ryd994
2015-04-30 21:05:59 +08:00
@gameliving 那剩下的给谁了?
还是说CLOSEWAIT?
CLOSEWAIT只能调低timeout,因为这是内核设计
quix
2015-04-30 21:47:11 +08:00
tcpkill 行不行

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/187493

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX