大部分人在寫Shell 過濾進程的時候 都會使用 grep 在 ps aux 的輸出結果中查找指定的進程,但此時也會把 grep 進程也顯示出來 比如查找 pptpd 進程,會匹配出來兩條: [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 常見的防止grep進程出現的方法就是在對加一個管道 grep -v grep 進行過濾: [root@selboo ~]# ps aux | grep pptp | grep -v grep root 22054 0.0 0.1 1952 608 ? Ss Oct22 0:00 /usr/sbin/pptpd 還有一個更方便的方法是用 正則 grep [p]ptpd來搜索pptpd這個進程: [root@selboo ~]# ps aux | grep [p]ptp root 22054 0.0 0.1 1952 608 ? Ss Oct22 0:00 /usr/sbin/pptpd 雖然說它比 grep -v grep 也未必方便多少,但是如果用大量循環的監控腳本上,每次都能減少一次系統grep調用,也就是減少一次創建進程,雖然提升很小可以忽略不計,但是用在shell寫的監控腳本上來說多少還有點提升的,優化就是注重細節嘛。 以下是執行五次測試結果: 使用grep -v grep 方式 [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 使用正則方式 [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 |
免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!
始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!
掃一掃,關注站長網微信