Назад | Перейти на главную страницу

Что означают процессы, перечисленные в скобках, в выводе ps (1) в системах, подобных OS X, и как их убить?

username@yosemite ~ % ps wwwaux | grep java
username        48111   0.0  0.0        0      0   ??  ?E   11:54AM   0:00.00 (java)
username        91673   0.0  0.0  2432772    508 s006  R+    3:19PM   0:00.00 grep java
username        90809   0.0  0.0        0      0   ??  ?E   12:47PM   0:00.00 (java)

Время от времени я получаю вот такое подвешивание JVM. Что делают (java) процесс листинги значит? Как мне их убить? kill -9 48111 ничего не делает, и AFAICT списки остаются там, пока я не перезагружусь.

В случае сомнений обратитесь к странице руководства :)

$ man ps
/parenth

When printing using the command keyword, a process that has exited and
has a parent that has not yet waited for the process (in other words,
a zombie) is listed as ``<defunct>'', and a process which is blocked
while trying to exit is listed as ``<exiting>''.  If the arguments
cannot be located (usually because it has not been set, as is the case
of system processes and/or kernel threads) the command name is printed
within square brackets.  The process can change the arguments shown
with setproctitle(3).  Otherwise, ps makes an educated guess as to the
file name and arguments given when the process was created by
examining memory or the swap area.  The method is inherently somewhat
unreliable and in any event a process is entitled to destroy this
information.  The ucomm (accounting) keyword can, however, be depended
on. If the arguments are unavailable or do not agree with the ucomm
keyword, the value for the ucomm keyword is appended to the arguments
in parentheses.

Дополнительно:

KEYWORDS
  The following is a complete list of the available keywords and their meanings.
  Several of them have aliases (keywords which are synonyms).
  ...
  ucomm      name to be used for accounting

Похоже, это зомби-процессы, и вместо того, чтобы просто возвращать <defunct> в качестве имени процесса он возвращает то, что было сохранено в какой-то учетной записи.

Что касается уничтожения этих процессов, перезагрузка может быть лучшим вариантом. Так как они потеряли свой исходный PPID и стали потомками PPID 1 (launchd). Вы можете попробовать послать сигнал HUP на launchd, но не пытайтесь послать ему сигнал SIGKILL или SIGTERM, иначе ваша система выйдет из строя.

Вы можете проверить PPID процессов зомби, используя ps -ef.

Заметка: наличие нескольких зомби-процессов ничего не должно повредить. На самом деле процесс больше не работает, он был остановлен и не использует никаких системных ресурсов, кроме записи в таблице процессов.