经常需要杀死某个进程,操作了几次之后,对一个熟练的码农来说,就要制作自己的工具了。有些工具虽然很小,但是却能节省一大部分的时间。

输入某个进程的ID并杀死的方法。这种事情,一般是先搜索再进行优化,这种对我这种不是大牛的人来说,是最快的方法:

果然不出所料,很快我就找到一个能用的脚本:

#!/bin/bash
echo "Input process name first"
read input1 PID=$(ps -e|grep $input1|awk '{printf $1}') if [ $? -eq ]; then
echo "process id:$PID"
else
echo "process $input1 not exit"
exit
fi kill - ${PID} if [ $? -eq ];then
echo "kill $input1 success"
else
echo "kill $input1 fail"
fi

可是,运行了几次之后,我发现了一个问题,就是这个脚本会把自己删除PID的线程也删掉,这种是删不掉的,所以总会报错。

找了一些资料,才发现里面有个问题需要解决:就是需要忽略当前的脚本即可:

pid=`ps -ef | grep "$filename" | grep -v "cgroup" | grep -v "grep" | awk '{print $2}'`

接下来,把这个脚本改成这样就很完美了:

#!/bin/bash
#echo "Input process name first"
#read input1 PID=`ps -ef | grep "arm-none-eabi-gdb" | grep -v "cgroup" | grep -v "grep" | awk '{print $2}'` if [ $? -eq ]; then
echo "process id:$PID"
else
echo "process $input1 not exit"
exit
fi kill - ${PID} if [ $? -eq ];then
echo "kill $input1 success"
else
echo "kill $input1 fail"
fi

顺便说明一下,grep -v 这个命令要好好用,以前用的太少了。也许,下面的这个例子能够清楚的给出这个关键字的含义和用法:

➜  scripts git:(master) ✗ ps -ef | grep "kill_gdb"
:30下午 ttys003 :00.00 sh kill_gdb.sh
:33下午 ttys003 :00.01 vim kill_gdb.sh
:38下午 ttys003 :00.02 vim kill_gdb.sh
:39下午 ttys003 :00.01 vim kill_gdb.sh
:40下午 ttys003 :00.01 vim kill_gdb.sh
:02下午 ttys003 :00.02 vim kill_gdb.sh
:04下午 ttys003 :00.00 grep --color=auto --exclude-dir=.bzr --exclude-dir=CVS --exclude-dir=.git --exclude-dir=.hg --exclude-dir=.svn kill_gdb
➜ scripts git:(master) ✗ ps -ef | grep "kill_gdb" | grep -v "grep"
:30下午 ttys003 :00.00 sh kill_gdb.sh
:33下午 ttys003 :00.01 vim kill_gdb.sh
:38下午 ttys003 :00.02 vim kill_gdb.sh
:39下午 ttys003 :00.01 vim kill_gdb.sh
:40下午 ttys003 :00.01 vim kill_gdb.sh
:02下午 ttys003 :00.02 vim kill_gdb.sh

shell脚本获取进程ID并杀死的实现及问题解析的更多相关文章

  1. 014-交互式Shell和shell脚本获取进程 pid

    Linux 的交互式 Shell 与 Shell 脚本存在一定的差异,主要是由于后者存在一个独立的运行进程 1.交互式 Bash Shell 获取进程 pid 在已知进程名(name)的前提下,交互式 ...

  2. shell脚本获取mysql插入数据自增长id的值

    shell脚本获取mysql插入数据自增长id的值 在shell脚本中我们可以通过last_insert_id()获取id值,但是,需要注意的是,该函数必须在执行插入操作的sql语句之后,立即调用,否 ...

  3. 用shell脚本监控进程是否存在 不存在则启动的实例

    用shell脚本监控进程是否存在 不存在则启动的实例,先上代码干货: #!/bin/shps -fe|grep processString |grep -v grepif [ $? -ne 0 ]th ...

  4. linux shell脚本监控进程是否存在

    用shell脚本监控进程是否存在 不存在则启动的实例,先上代码干货:    #!/bin/shps -fe|grep processString |grep -v grepif [ $? -ne 0 ...

  5. 在 shell 脚本获取 ip、数字转换等网络操作

    在 shell 脚本获取 ip.数字转换等网络操作 ip 和数字的相互转换 ip转换为数字 :: function ip2num() { local ip=$1 local a=$(echo $ip ...

  6. 如何通过进程名获取进程ID

    博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:如何通过进程名获取进程ID.

  7. linux与windows查看占用端口的进程ID并杀死进程

    有时候tomcat出现端口被占用,需要查出进程ID并杀死进程. 1.查找占用端口的进程ID(windows与linux一样  8005也可以加上引号   grep可以用findstr替换) 6904就 ...

  8. 关于使用java执行shell脚本获取centos的硬盘序列号和mac地址

    1.获取硬盘序列号: 新建shell脚本文件: identifier.sh, 内容为: diskdata=`fdisk -l` diskleft=${diskdata#*"identifie ...

  9. python获取进程id号:

    python获取进程id号: os.getpid()获取当前进程id os.getppid()获取父进程id

随机推荐

  1. 1. 开篇-springboot环境搭建

    最初学习strurs2时,虽然觉得也挺好用的,但也有一些不便的地方:1. 模型绑定必须要在Action中声明对应模型的成员变量:2. Action中对外提供调用的接口必须明确注明:3. 要声明一大堆的 ...

  2. volume_manager.go

    package ) type) ],,) ,)             vms.CanCreateVolume = false         } else {             vms.Can ...

  3. 图解java中的bytebuffer

    因何而写 网上关于bytebuffer的文章真的很多,为何在此还要写一篇呢?主要是基于以下几点考虑 很多人在使用t-io时,还不会bytebuffer,只会照着t-io提供的例子照猫画虎,不利于灵活运 ...

  4. noip 2015 斗地主 大爆搜!!!

    反正肯定是大模拟 但是每一个可以出的牌都搜一定不是最优的 考虑最特殊的出牌方案:顺子(单,对,三) 每一种方案再加上暴力贪心打出剩下的牌的步数 #include<cstdio> #incl ...

  5. Dubbo原理和源码解析之服务引用

    一.框架设计 在官方<Dubbo 开发指南>框架设计部分,给出了引用服务时序图: 另外,在官方<Dubbo 用户指南>集群容错部分,给出了服务引用的各功能组件关系图: 本文将根 ...

  6. C++ bitset用法

    概念: bitset是用来存储位的(其中的元素只有两种形式) 这个类通常用来模拟一个布尔数组,但对空间分配上进行了优化:通常,每个元素只占用一个bit ,而通常char类型是它的八倍 每个位置上的位都 ...

  7. 招商信诺生产jvm 配置和自己的eclipse jdk配置

    command=/usr/bin/java -jar -Xms512m -Xmx512m -Xss256K -XX:PermSize=256m -XX:MaxPermSize=512m -XX:+Us ...

  8. Eureka的功能特性及相关配置

    1.服务提供者1.1服务注册服务提供者启动时,会通过rest请求的方式将自己注册到Eureka Server上,同时带上了自身服务的一些元数据信息.Eureka Server接收到请求后,将元数据信息 ...

  9. java日志文件用法总结

    1.基本概念 日志门面(接口):commons logging ; slf4j ; 日志具体实现:log4j ; logback(Spring 系列在使用) ; log4j2(添加了异步logger的 ...

  10. [日志分析] Access Log 日志分析

    0x00.前言: 如何知道自己所在的公司或单位是否被入侵了?是没人来“黑”,还是因自身感知能力不足,暂时还没发现?入侵检测是每个安全运维人员都要面临的严峻挑战.安全无小事,一旦入侵成功,后果不堪设想. ...