<delect id="sj01t"></delect>
  1. <em id="sj01t"><label id="sj01t"></label></em>
  2. <div id="sj01t"></div>
    1. <em id="sj01t"></em>

            <div id="sj01t"></div>
            操作系統

            Linux系統中查殺僵尸進程方法介紹

            時間:2025-03-01 21:53:20 操作系統 我要投稿
            • 相關推薦

            Linux系統中查殺僵尸進程方法介紹

              在UNIX 系統中,一個進程結束了,但是他的父進程沒有等待(調用wait / waitpid)他, 那么他將變成一個僵尸進程. 在fork()/execve()過程中,假設子進程結束時父進程仍存在,而父進程fork()之前既沒安裝SIGCHLD信號處理函數調用 waitpid()等待子進程結束,又沒有顯式忽略該信號,則子進程成為僵尸進程。

              一個進程在調用exit命令結束自己的生命的時候,其實它并沒有真正的被銷毀, 而是留下一個稱為僵尸進程(Zombie)的數據結構(系統調用exit,它的作用是 使進程退出,但也僅僅限于將一個正常的進程變成一個僵尸進程,并不能將其完全銷毀)

              進程的危害

              由于子進程的結束和父進程的運行是一個異步過程,即父進程永遠無法預測子進程 到底什么時候結束. 那么會不會因為父進程太忙來不及wait子進程,或者說不知道 子進程什么時候結束,而丟失子進程結束時的狀態信息呢? 不會。因為UNⅨ提供了一種機制可以保證只要父進程想知道子進程結束時的狀態信息, 就可以得到。這種機制就是: 在每個進程退出的時候,內核釋放該進程所有的資源,包括打開的文件,占用的內存等。但是仍然為其保留一定的信息(包括進程號the process ID,退出狀態the termination status of the process,運行時間the amount of CPU time taken by the process等)。直到父進程通過wait / waitpid來取時才釋放. 但這樣就導致了問題,如果進程不調用wait / waitpid的話,那么保留的那段信息就不會釋放,其進程號就會一直被占用,但是系統所能使用的進程號是有限的,如果大量的產生僵死進程,將因為沒有可用的進程號而導致系統不能產生新的進程. 此即為僵尸進程的危害,應當避免。

              1、如何查看僵尸進程?

              如何查看linux系統上的僵尸進程,如何統計有多少僵尸進程?

              #ps -ef | grep defunct

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

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

              Tasks: 95 total, 1 running, 94 sleeping, 0 stopped, 0 zombie

              top命令中也統計了僵尸進程。或者使用下面的命令:

              ps -ef | grep defunct | grep -v grep | wc -l

              2、如何殺死僵尸進程?

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

              ps -e -o ppid,stat | grep Z | cut –d” ” -f2 | xargs kill -9

              或

              kill -HUP `ps -A -ostat,ppid | grep -e ’^[Zz]‘ | awk ’{print $2}’`

              當然您可以自己編寫更好的shell腳本,歡迎與大家分享。

              另外子進程死后,會發送SIGCHLD信號給父進程,父進程收到此信號后,執行waitpid()函數為子進程收尸。就是基于這樣的原理:就算父進程沒有調用wait,內核也會向它發送SIGCHLD消息,而此時,盡管對它的默認處理是忽略,如果想響應這個消息,可以設置一個處理函數。

              3、如何避免僵尸進程?

              處理SIGCHLD信號并不是必須的。但對于某些進程,特別是服務器進程往往在請求到來時生成子進程處理請求。如果父進程不等待子進程結 束,子進程將成為僵尸進程(zombie)從而占用系統資源。如果父進程等待子進程結束,將增加父進程的負擔,影響服務器進程的并發性能。在Linux下 可以簡單地將 SIGCHLD信號的操作設為SIG_IGN。

              signal(SIGCHLD,SIG_IGN);

              這樣,內核在子進程結束時不會產生僵尸進程。這一點與BSD4不同,BSD4下必須顯式等待子進程結束才能釋放僵尸進程;或者用兩次fork(),而且使緊跟的子進程直接退出,是的孫子進程成為孤兒進程,從而init進程將負責清除這個孤兒進程。

            【Linux系統中查殺僵尸進程方法介紹】相關文章:

            linux系統中快速查看進程pid的方法10-06

            解析Linux系統中的進程調度06-19

            Linux系統中的守護進程講解08-21

            解讀Linux系統中的進程調度08-01

            Linux系統下的進程切換的解析08-03

            Linux系統中命令的學習方法05-29

            Linux系統如何查看進程的線程數06-07

            Linux系統中sleep的使用方法07-17

            linux操作系統要查看系統進程的辦法07-24

            <delect id="sj01t"></delect>
            1. <em id="sj01t"><label id="sj01t"></label></em>
            2. <div id="sj01t"></div>
              1. <em id="sj01t"></em>

                      <div id="sj01t"></div>
                      黄色视频在线观看