Что такое зомби-процессы?
С такими командами, как top
и графический интерфейс System Monitor
Я вижу, что на данный момент у меня есть несколько процессов зомби.
Что такое зомби-процессы?
Влияют ли они на производительность системы или приложения, к которому они относятся? Они используют слишком много памяти или вообще никакой памяти?
5 ответов
Зомби - это МЕРТВЫЕ процессы. Их нельзя "убить" (вы не можете убить МЕРТВУ). Все процессы в конечном итоге умирают, и когда они это делают, они становятся зомби. Они почти не потребляют ресурсов, чего и следовало ожидать, потому что они мертвы! Причиной для зомби является то, что родитель (процесс) зомби может получить информацию о состоянии выхода из зомби и статистику использования ресурсов. Родитель сообщает операционной системе, что зомби больше не нужен, используя один из системных вызовов wait().
Когда процесс умирает, все его дочерние процессы становятся дочерними для процесса номер 1, который является процессом init. Init - это "всегда", ожидая смерти детей, чтобы они не оставались зомби.
Если у вас есть процессы зомби, это означает, что их родители не ожидали этих зомби (посмотрите на PPID, отображаемый ps -l
). У вас есть три варианта: исправить родительский процесс (заставить его ждать); убить родителя; или жить с этим. Помните, что жить с ним не так сложно, потому что зомби занимают чуть больше одной дополнительной строки в выводе ps.
Зомби можно идентифицировать в выходных данных команды Unix ps по наличию "Z" в столбце STAT. Зомби, которые существуют в течение более короткого периода времени, обычно указывают на ошибку в родительской программе. Как и в случае других утечек, присутствие нескольких зомби само по себе не вызывает беспокойства, но может указывать на проблему, которая может стать серьезной при более высоких нагрузках.
Чтобы удалить зомби из системы, сигнал SIGCHLD можно отправить родителю вручную, используя команду kill. Если родительский процесс по-прежнему отказывается пожинать зомби, следующим шагом будет удаление родительского процесса. Когда процесс теряет своего родителя, init становится его новым родителем. Init периодически выполняет системный вызов wait, чтобы пожинать зомби с init в качестве родителя.
Существуют также потерянные процессы, которые являются компьютерным процессом, родительский процесс которого завершен или завершен.
Процесс может стать осиротевшим во время удаленного вызова, когда происходит сбой клиентского процесса после выполнения запроса от сервера.
Сироты тратят впустую ресурсы сервера и потенциально могут оставить сервер в беде (Это самая большая разница в ресурсах между зомби и сиротами (за исключением случаев, когда вы видите какой-нибудь фильм о зомби-сиротах). Однако существует несколько способов решения проблемы процесса-сироты:
Истребление является наиболее часто используемой техникой; в этом случае сиротский процесс убит.
Реинкарнация - это техника, при которой машины периодически пытаются найти родителей любых удаленных вычислений; в этот момент осиротевшие процессы убиты.
Истечение срока действия - это метод, при котором каждому процессу отводится определенное время для завершения, прежде чем он будет убит. В случае необходимости, процесс может "попросить" предоставить больше времени до истечения выделенного времени.
Процесс также может быть потерян, если он запущен на том же компьютере, что и его родительский процесс. В UNIX-подобной операционной системе любой потерянный процесс будет немедленно принят специальным системным процессом init. Эта операция называется переопределением и происходит автоматически. Хотя технически процесс имеет процесс init в качестве своего родителя, он все еще называется процессом-сиротой, так как процесс, который первоначально его создал, больше не существует.
Больше информации:
http://wiki.answers.com/Q/What_is_Zombie_Process_and_Orphan_Process
http://www.linuxsa.org.au/tips/zombies.html
http://www.brighthub.com/computing/linux/articles/79186.aspx
Зомби-процессы (также показывают, как <defunct>
), не являются реальными процессами вообще. Это просто записи в таблице процессов ядра. Это единственный ресурс, который они потребляют. Они не потребляют ни CPU, ни RAM. Единственная опасность наличия зомби - это нехватка места в таблице процессов (вы можете использовать cat /proc/sys/kernel/threads-max
чтобы увидеть, сколько записей разрешено в вашей системе).
Они появляются только тогда, когда их родительский процесс (т.е. процесс, который fork()'ed
их) жив, но еще не звонил wait()
системная функция. Когда родитель умирает, зомби wait()'ed
для init
и исчезнуть.
Когда child process
завершается, его смерть сообщается его родителю, чтобы родитель мог предпринять некоторые соответствующие действия.
process
то, что ожидает своего родителя, чтобы принять его код возврата, называется процессом зомби.
У них есть completed their execution
но все еще имеет entry
в process table
,
Зомби-процессы - это процессы, которые прекратили работу, но их запись в таблице процессов все еще существует, потому что родительский процесс не получил ее через системный вызов ожидания. Технически каждый процесс, который завершается, является зомби в течение очень короткого периода времени, но они могут жить дольше.
Долгоживущие процессы зомби происходят, когда родительские процессы не вызывают системный вызов wait после завершения дочернего процесса. Одна из ситуаций, когда это происходит, - когда родительский процесс плохо написан и просто пропускает вызов ожидания, или когда родительский процесс умирает до того, как дочерний процесс и новый родительский процесс не вызывает ожидание этого. Когда родительский процесс умирает раньше дочернего, ОС назначает дочерний процесс процессу "init" или PID 1. То есть процесс init "принимает" дочерний процесс и становится его родителем. Это означает, что теперь, когда дочерний процесс завершает работу, новый родительский элемент (init) должен вызвать wait, чтобы получить свой код выхода, или его запись в таблице процессов останется навсегда, и он станет зомби.
Во второй строке видно, что в моей системе запущен 1 зомби-процесс.
Если вам нужны дополнительные сведения о процессе зомби, используйте следующую команду:
$ ps axo stat,ppid,pid,comm | grep -w defunct
Убийство зомби-процесса:
$ kill -s SIGCHLD PID