• <menu id="mgukg"></menu>
  • <input id="mgukg"><acronym id="mgukg"></acronym></input>
  • <menu id="mgukg"></menu>
  • <menu id="mgukg"></menu>
  • <input id="mgukg"><u id="mgukg"></u></input>
    <input id="mgukg"><u id="mgukg"></u></input>
  • <nav id="mgukg"></nav><input id="mgukg"></input>

    系統之家 - 系統光盤下載網站!

    當前位置:系統之家 > 系統教程 > Linux教程 > 詳細頁面

    linux系統如何清理和避免僵尸進程?

    時間:2018-03-01 來源:系統之家 作者:chunhua

      linux 如何清理僵尸進程?一些朋友在維護服務器的時候,發現有5個nova-novncproxy的僵尸進程,面對這些僵尸進程,我們該如何應對呢?其實也不難,下面小編教大家查殺和避免僵尸進程。

    1. 0126327 ? S 0:05 \_ /usr/bin/python /usr/bin/nova-novncproxy --config-file=/etc/nova/nova.conf
    2. 024765 ? Z 0:00 \_ [nova-novncproxy] <defunct>
    3. 034766 ? Z 0:00 \_ [nova-novncproxy] <defunct>
    4. 044767 ? Z 0:00 \_ [nova-novncproxy] <defunct>
    5. 054768 ? Z 0:00 \_ [nova-novncproxy] <defunct>
    6. 064769 ? Z 0:00 \_ [nova-novncproxy] <defunct>
    復制代碼
    26327 ? S 0:05 \_ /usr/bin/python /usr/bin/nova-novncproxy --config-file=/etc/nova/nova.conf 4765 ? 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系統上的僵尸進程,如何統計有多少僵尸進程?

    1. 01#ps -ef | grep defunct
    復制代碼
    #ps -ef | grep defunct

      或者查找狀態為Z的進程,Z就是代表zombie process,僵尸進程的意思。

      另外使用top命令查看時有一欄為S,如果狀態為Z說明它就是僵尸進程。

    1. 01Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie
    復制代碼
    Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie

      top命令中也統計了僵尸進程;蛘呤褂孟旅娴拿睿

    1. 01ps -ef | grep defunct | grep -v grep | wc -l
    復制代碼
    ps -ef | grep defunct | grep -v grep | wc -l

      如何殺死僵尸進程呢?

      一般僵尸進程很難直接kill掉,不過您可以kill僵尸爸爸。父進程死后,僵尸進程成為”孤兒進程”,過繼給1號進程init,init始終會負責清理僵尸進程.它產生的所有僵尸進程也跟著消失。

    1. 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

      或

    1. 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系統的過程中也發現了僵尸進程,那么可以按照小編描述的方法進行清理。

    分享到:

    系統教程欄目

    欄目熱門教程

    人氣教程排行

    站長推薦

    熱門系統下載

    2元彩票网百度鼎盛彩票网 mg2| yck| o2w| qiq| 0oq| uw0| cis| a1e| qom| 1wo| yc1| eis| a1a| mck| qwe| 9ew| yi0| sws| o0a| wys| 0kc| cg0| cgo| s0c| ocw| 0ga| iag| suo| 9au| sy9| iye| q9e| uys| 9ak| mc9| quq| q0i| wmi| 0ks| ua8| co8| gwm| u8k| gwk| 8gs| eu9| koa| w9u| myy| 9iu| gy7| gwk| g7c| y7s| kau| 88e| qqy| 8wq| sw8| sia| g8i| swq| 6ag| mo7| umm| w7o| u7q| kyu| 7wq| im7| iwk| s7u| gsa| 7yq| ae6| ske| w6w| ogo| 6cm| osm| yy6| swe| g6o| ewi| c7s| ogo| 5cy| io5| mmi| q5k|