前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >1 分钟小技巧系列 | 如何在不杀进程的前提下关闭一个 TCP Socket 连接

1 分钟小技巧系列 | 如何在不杀进程的前提下关闭一个 TCP Socket 连接

作者头像
iMike
发布2019-08-20 15:01:39
2.8K0
发布2019-08-20 15:01:39
举报
文章被收录于专栏:运维之美运维之美

要在线关闭一个 TCP Socket 连接,你可能会说很简单,netstat -antp 找到连接,kill 掉这个进程就行了。

代码语言:javascript
复制
# netstat -antp|grep 6789
tcp        0      0 1.1.1.1:59950      1.1.1.2:6789        ESTABLISHED 45059/ceph-fuse
# kill 45059

连接确实关掉了,进程也跟着一起杀死了。达不到 “在线” 的要求。

有没有办法不杀死进程,但还是可以关闭 Socket 连接呢?

我们知道,在编码的时候,要关闭一个 Socket,只要调用 close 函数就可以了,但是进程在运行着呢,怎么让它调用 close 呢?

在 superuser 上看到一个很棒的方法,原理就是 gdb attach 到进程上下文,然后 call close($fd)。

  1. 使用 netstat 找到进程
代码语言:javascript
复制
# netstat -antp|grep 6789
tcp        0      0 1.1.1.1:59950      1.1.1.2:6789        ESTABLISHED 45059/ceph-fuse

如上,进程 pid 为 45059。

  1. 使用 lsof 找到进程 45059 打开的所有文件描述符,并找到对应的 Socket 连接。
代码语言:javascript
复制
# lsof -np 45059
COMMAND     PID USER   FD   TYPE             DEVICE SIZE/OFF       NODE NAME
ceph-fuse 45059 root  rtd    DIR                8,2     4096          2 /
ceph-fuse 45059 root  txt    REG                8,2  6694144    1455967 /usr/bin/ceph-fuse
ceph-fuse 45059 root  mem    REG                8,2   510416    2102312 /usr/lib64/libfreeblpriv3.so
...
ceph-fuse 45059 root   12u  IPv4         1377072656      0t0        TCP 1.1.1.1:59950->1.1.1.2:smc-https (ESTABLISHED)

其中 12u 就是上面对应 Socket 连接的文件描述符。

  1. gdb 连接到进程
代码语言:javascript
复制
$ gdb -p 45059
  1. 关闭 Socket 连接
代码语言:javascript
复制
(gdb) call close(12u)

Socket 连接就可以关闭了,但是进程 45059 还是好着的。

你可能会问,什么时候会用到这个特性呢?场景还是比较多的,比如你想测试下应用是否会自动重连 MySQL,通过这个办法就可以比较方便的测试了。

来源:Zlatan Eevee 原文:http://t.cn/AijmTykM 题图:来自谷歌图片搜索 版权:本文版权归原作者所有 投稿:欢迎投稿,邮箱: editor@hi-linux.com

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-08-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 奇妙的Linux世界 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档