正在加载...

shell grep 查找进程的小技巧

[ 2012/12/29 17:34 | by selboo ]

        大部分人在写Shell 过滤进程的时候  都会使用 grep  在 ps aux 的输出结果中查找指定的进程,但此时也会把 grep 进程也显示出来 比如查找 pptpd 进程,会匹配出来两条:

This is The Code
[root@selboo ~]# ps aux | grep pptp
root     20191  0.0  0.2   5108   704 pts/2    R+   16:58   0:00 grep pptp
root     22054  0.0  0.1   1952   608 ?        Ss   Oct22   0:00 /usr/sbin/pptpd
Parsed in 0.000 seconds at N/A

常见的防止grep进程出现的方法就是在对加一个管道 grep -v grep 进行过滤:

This is The Code
[root@selboo ~]# ps aux | grep pptp | grep -v grep
root     22054  0.0  0.1   1952   608 ?        Ss   Oct22   0:00 /usr/sbin/pptpd
Parsed in 0.000 seconds at N/A

还有一个更方便的方法是用 正则 grep [p]ptpd来搜索pptpd这个进程:

This is The Code
[root@selboo ~]# ps aux | grep [p]ptp  
root     22054  0.0  0.1   1952   608 ?        Ss   Oct22   0:00 /usr/sbin/pptpd
Parsed in 0.000 seconds at N/A


      虽然说它比 grep -v grep 也未必方便多少,但是如果用大量循环的监控脚本上,每次都能减少一次系统grep调用,也就是减少一次创建进程,虽然提升很小可以忽略不计,但是用在shell写的监控脚本上来说多少还有点提升的,优化就是注重细节嘛。

以下是执行五次测试结果:

使用grep -v grep 方式

This is The Code
[root@selboo etc]# time for (( i=1; i<=200; i++ )) ;do ps aux | grep pptp | grep -v pptp  &>/dev/null; done
real    0m1.487s  0m1.475s  0m1.488s  0m1.497s  0m1.499s
user    0m0.335s  0m0.328s  0m0.334s  0m0.326s  0m0.312s
sys     0m0.766s  0m0.757s  0m0.772s  0m0.784s  0m0.795s
Parsed in 0.000 seconds at N/A

使用正则方式

This is The Code
[root@selboo etc]# time for (( i=1; i<=200; i++ )) ;do ps aux | grep [p]ptp  &>/dev/null; done
real    0m1.306s  0m1.344s  0m1.303s  0m1.298s  0m1.329s
user    0m0.343s  0m0.313s  0m0.326s  0m0.274s  0m0.322s
sys     0m0.742s  0m0.801s  0m0.753s  0m0.798s  0m0.784s
Parsed in 0.000 seconds at N/A

最后编辑: selboo 编辑于2012/12/29 17:48
,
fage
2013/05/04 22:48
能解释下为啥加了grep [p]ptp后就没有grep pptp这行了,谢谢了
selboo 回复于 2013/05/08 13:54
正常执行
ps aux | grep pptpd
root      9666  0.0  0.0 103296   816 pts/1    S+   08:42   0:00 grep pptpd
root     20133  0.0  0.0  10468    84 ?        Ss   May01   0:00 /usr/sbin/pptpd

使用正则
ps aux | grep [p]ptpd
root     20133  0.0  0.0  10468    84 ?        Ss   May01   0:00 /usr/sbin/pptpd

其实上面 正则还有一条 如下, 关键是下面一条  “grep [p]ptpd”  这里只是 文本
root      9614  0.0  0.0 101068   800 pts/1    S+   08:38   0:00 grep [p]ptpd

而正则匹配的是  [p]ptpd 也就是 pptpd  和 上面 grep [p]ptpd 不匹配所以没有显示。

由于评论不能加颜色,可能看着不太直观,还不清楚的话,我可以发篇文章解释下。
shell
2013/01/04 11:10
现在服务器那么NB,为了提高Shell  0.1s 而改掉个人习惯问题,得不偿失呀。要是C/C++ 还可以考虑下。
分页: 1/1 第一页 1 最后页
发表评论
表情
打开HTML
打开UBB
打开表情
隐藏
记住我
昵称   密码   游客无需密码
网址   电邮   [注册]