博客
关于我
Linux下通过端口杀死进程
阅读量:790 次
发布时间:2023-02-03

本文共 1641 字,大约阅读时间需要 5 分钟。

1 netstat -nlp 查看占用端口号的服务
2 找到该端口号的进程
3 找到该进程id
4 kill它

程序可以一点一点来:

1 查看占用端口号的服务

[root@aslibra root]# netstat -nlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name  
tcp        0      0 0.0.0.0:3306            0.0.0.0:*               LISTEN      23946/              
tcp        0      0 0.0.0.0:3307            0.0.0.0:*               LISTEN      12711/              
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      3936/httpd          
tcp        0      0 0.0.0.0:21              0.0.0.0:*               LISTEN      3910/              
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      3753/sshd          
tcp        0      0 0.0.0.0:25              0.0.0.0:*               LISTEN      3786/              
Active UNIX domain sockets (only servers)
Proto RefCnt Flags       Type       State         I-Node PID/Program name    Path
unix  2      [ ACC ]     STREAM     LISTENING     827412 23946/              /tmp/mysql.sock
unix  2      [ ACC ]     STREAM     LISTENING     733272 12711/              ./mysql.sock


(省掉了一些内容)

2 可以用grep筛选一下,看看规律,找到有 :3306 的一行就好
用管道符给grep处理:

[root@aslibra root]# netstat -nlp | grep :3306
tcp        0      0 0.0.0.0:3306            0.0.0.0:*               LISTEN      23946/


既然取出一行了,那就容易了,再筛选一下,用awk分割取出其中一个

3 读取出端口号

[root@aslibra root]# netstat -nlp | grep :3306 | awk '{print $7}'
23946/


意思是取第七个字段,这里默认应该是用tab字符分割的,已经读取出来了,但是还得拿到/前面的数字

4 取/前面的数字就可以了,这里还是可以用awk处理

[root@aslibra root]# netstat -nlp | grep :3306 | awk '{print $7}' | awk -F"/" '{ print $1 }'
23946


意思是用/符号分割,取第一部分

5 然后把这个数字传给kill就可以

kill命令不能跟在管道符后面继续处理了,会出错的

[root@aslibra root]# netstat -nlp | grep :3306 | awk '{print $7}' | awk -F"/" '{ print $1 }' | kill
kill: usage: kill [-s sigspec | -n signum | -sigspec] [pid | job]... or kill -l [sigspec]


需要用到"[']"操作符,它可以执行一个语句,这个可以如此执行:

kill [']netstat -nlp | grep :3306 | awk '{print $7}' | awk -F"/" '{ print $1 }'[']


好了,任务完成了,之后贴一下awk的介绍,挺使用
当然,有更加精简的写法,这里只是描述思路的实现

转载于:https://www.cnblogs.com/peter9/archive/2011/07/28/2362156.html

你可能感兴趣的文章
Linux 的NFS服务的配置
查看>>
linux 的sh脚本中的-p、2>&1 &、$!、[]、-f、grep、awk、-z 相关的操作
查看>>
linux 的vi vim 的常用的基本命令
查看>>
Linux 的性能调优的思路
查看>>
Linux 的文本搜索命令 grep
查看>>
Linux 的账号与群组管理
查看>>
linux 目录&基础命令
查看>>
Linux 目录结构
查看>>
Linux 硬链接和软链接到底是什么?怎么理解?
查看>>
Linux 磁盘分区详解
查看>>
Linux 磁盘和文件系统管理1
查看>>
Linux 磁盘和文件系统管理2
查看>>
Linux 磁盘满了不用慌,这几个命令在手不断梭哈就好
查看>>
Linux 磁盘管理
查看>>
Linux 磁盘管理及监控与性能评估
查看>>
Linux 示例中的 apt 命令大全
查看>>
linux 禁用磁盘密码,linux 磁盘加密保护
查看>>
Linux 系统备份与恢复详解
查看>>
Linux 系统安装 Mongodb 数据库
查看>>
Linux 系统安装MySQL
查看>>