linux系統如何清理和避免僵尸進程?
linux 如何清理僵尸進程?一些朋友在維護服務器的時候,發現有5個nova-novncproxy的僵尸進程,面對這些僵尸進程,我們該如何應對呢?其實也不難,下面小編教大家查殺和避免僵尸進程。
0126327 ?S 0:05 _ /usr/bin/python /usr/bin/nova-novncproxy --config-file=/etc/nova/nova.conf024765 ?Z 0:00 _ [nova-novncproxy] <defunct>034766 ?Z 0:00 _ [nova-novncproxy] <defunct>044767 ?Z 0:00 _ [nova-novncproxy] <defunct>054768 ?Z 0:00 _ [nova-novncproxy] <defunct>064769 ?Z 0:00 _ [nova-novncproxy] <defunct>復制代碼26327 ?S 0:05 _ /usr/bin/python /usr/bin/nova-novncproxy --config-file=/etc/nova/nova.conf4765 ?Z 0:00 _ [nova-novncproxy] <defunct>4766 ?Z 0:00 _ [nova-novncproxy] <defunct>4767 ?Z 0:00 _ [nova-novncproxy] <defunct>4768 ?Z 0:00 _ [nova-novncproxy] <defunct>4769 ?Z 0:00 _ [nova-novncproxy] <defunct>定義:
In UNIX System terminology, a process that has terminated,but whose parent has not yet waited for it, is called a zombie.
在UNIX 系統中,一個進程結束了,但是他的父進程沒有等待(調用wait / waitpid)他, 那么他將變成一個僵尸進程。 在fork()/execve()過程中,假設子進程結束時父進程仍存在,而父進程fork()之前既沒安裝SIGCHLD信號處理函數調用 waitpid()等待子進程結束,又沒有顯式忽略該信號,則子進程成為僵尸進程。
如何查看linux系統上的僵尸進程,如何統計有多少僵尸進程?
01#ps -ef | grep defunct復制代碼#ps -ef | grep defunct或者查找狀態為Z的進程,Z就是代表zombie process,僵尸進程的意思。
另外使用top命令查看時有一欄為S,如果狀態為Z說明它就是僵尸進程。
01Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie復制代碼Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombietop命令中也統計了僵尸進程。或者使用下面的命令:
01ps -ef | grep defunct | grep -v grep | wc -l復制代碼ps -ef | grep defunct | grep -v grep | wc -l如何殺死僵尸進程呢?
一般僵尸進程很難直接kill掉,不過您可以kill僵尸爸爸。父進程死后,僵尸進程成為”孤兒進程”,過繼給1號進程init,init始終會負責清理僵尸進程.它產生的所有僵尸進程也跟著消失。
01ps -e -o ppid,stat | grep Z | cut -d” ” -f2 | xargs kill -9復制代碼ps -e -o ppid,stat | grep Z | cut -d” ” -f2 | xargs kill -9或
01kill -HUP `ps -A -ostat,ppid | grep -e ’^[Zz]‘ | awk ’{print $2}’`復制代碼kill -HUP `ps -A -ostat,ppid | grep -e ’^[Zz]‘ | awk ’{print $2}’`當然您可以自己編寫更好的shell腳本,歡迎與大家分享。
我將nova-novncproxy stop后再start,僵尸進程即消失,問題解決。
另外子進程死后,會發送SIGCHLD信號給父進程,父進程收到此信號后,執行waitpid()函數為子進程收尸。就是基于這樣的原理:就算父進程沒有調用wait,內核也會向它發送SIGCHLD消息,而此時,盡管對它的默認處理是忽略,如果想響應這個消息,可以設置一個處理函數。
如何避免僵尸進程呢?
處理SIGCHLD信號并不是必須的。但對于某些進程,特別是服務器進程往往在請求到來時生成子進程處理請求。如果父進程不等待子進程結束,子進程將成為僵尸進程(zombie)從而占用系統資源。如果父進程等待子進程結束,將增加父進程的負擔,影響服務器進程的并發性能。在Linux下 可以簡單地將 SIGCHLD信號的操作設為SIG_IGN。
signal(SIGCHLD,SIG_IGN);
這樣,內核在子進程結束時不會產生僵尸進程。這一點與BSD4不同,BSD4下必須顯式等待子進程結束才能釋放僵尸進程
或者
用兩次fork(),而且使緊跟的子進程直接退出,是的孫子進程成為孤兒進程,從而init進程將負責清除這個孤兒進程。
關于linux系統清理僵尸進程的操作步驟就給大家分享到這里了,如果你在操作linux系統的過程中也發現了僵尸進程,那么可以按照小編描述的方法進行清理。
相關文章:
1. Fedora系統外觀怎么設置? Fedora Linux外觀主題設置技巧2. Freebsd 雙硬盤無法啟動的解決辦法3. 去掉系統快捷方式箭頭的途徑——修改注冊表4. 支持深色 / 淺色模式,微軟 Win11 Build 25281 為“產品密鑰”窗口啟用新界面5. mac程序沒反應怎么辦 mac強制關閉程序的方法6. 世界上最流行的操作系統不是Linux或者Windows,而是MINIX7. YunDetectService.exe是什么進程?YunDetectService.exe禁止使用的方法8. Win11Beta預覽版22621.1180和22623.1180發布 附KB5022363內容匯總9. rsync結合 inotfiy 實現實時備份的問題10. Mac版steam錯誤代碼118怎么解決?Mac版steam錯誤代碼118解決教程