Shell脚本运行中的停止方法实现
linux系统shell中提交了一个脚本,但是需要停止这个进程,如何处理?
方式1
killall file-flume-kafka
说明:killall是一个命令,不是kill all,file-flume-kafka是脚本名,此方法简单粗暴。
方式二
ssh $i "ps -ef | grep file-flume-kafka | grep -v grep | awk '{print \$2}' | xargs kill"
ps参数:
-e:显示所有进程
-f:全格式显示
ps -ef 第二个参数就是进程id
grep file-flume-kafka | grep -v grep,file-flume-kafka为脚本名,并去除包含grep的行,避免影响最终结果正确性
grep aaa | grep -v bbb:可以过滤掉查询aaa结果中包含了bbb的行。
grep -v 可以理解为 grep not
举例:cat test.log | grep "login"|grep -v "devicetype"表示找出test.log中包含login关键字,且没有devicetype这个字段的行
awk ‘{print $2}':逐行的读入,以空格为默认分隔符将每行切片,取第二行。
awk参数 -f : 指定输入文件折分隔符。
比如awk -f : ‘/^root/{print $7}' passwd 表示搜索passwd文件以root关键字开头的所有行,并输出该行的第7列。
xargs kill:将前面的运行结果作为kill命令的参数运行。
xargs表示取出前面命令运行的结果,作为后面命令的输入参数。
xargs可选项:-n1,将每一个参数传给后面命令依次执行。
特别注意:
ssh $i 是登录到你执行脚本的那台虚拟机上,i代表虚拟机名字,非本机登录需要设置免密。当在本机上进行此操作时,无需执行这个命令。另外后面$2前的转义\也必须省略,无需转义。命令如下:
ps -ef | grep file-flume-kafka | grep -v grep | awk '{print $2}' | xargs kill
具体例子如下:
假设这个是我正在运行的脚本,我想kill它,但是我不知道他的进程号,只知道脚本的名称。
我的脚本名称为dws-dwt.sh,根据过滤条件我查找出脚本有两个进程号,为什么会这样呢?
因为你查找进程时用到了grep命令,而这个命令执行的时候带有你查找的进程参数,同时这也是一个进程。
例如 这条命令 ps -ef | grep dws-dwt.sh
其实是分两步执行的 先执行ps -ef 再执行 grep dws-dwt.sh
这个命令本身执行的时候也是一个进程,并把也带有dws-dwt.sh。
所以你要查找dws-dwt.sh
进程,需要把 grep dws-dwt.sh
这个进程过滤掉,才是最后的结果,怎么过滤呢,肯定不能用dws-dwt.sh做关键字,只能用grep做关键字
执行结果有两个进程号:
ps -ef | grep dws-dwt.sh
最终结果,得到进程号:
#执行命令停止进程 ps -ef | grep dws-dwt.sh | grep -v grep | awk '{print $2}' | xargs kill
到此这篇关于shell脚本运行中的停止方法实现的文章就介绍到这了,更多相关shell脚本运行中的停止方法内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
上一篇: Linux上搭载Nginx负载均衡配置使用案例详解
下一篇: Shell编程控制结构的基本使用