НАЗВА
pgrep, pkill, pidwait — пошук, надсилання сигналів процесам або очікування на завершення роботи процесів на основі даних щодо їхньої назви та інших атрибутів
КОРОТКИЙ ОПИС
pgrep
[параметри]
взірець
pkill
[параметри]
взірець
pidwait
[параметри]
взірець
ОПИС
pgrep виконує пошук серед поточних запущених процесів і виводить список ідентифікаторів процесів, які відповідають критерію вибору до stdout. Виконуватися мають усі критерії. Наприклад,
$ pgrep -u root sshd
покаже список процесів, які мають назву sshd і належать root. З іншого боку,
$ pgrep -u root,daemon
виведе список процесів, власником яких є root або daemon.
pkill надішле вказаний сигнал (типово SIGTERM) кожному процесу, замість виведення списку процесів до stdout.
pidwait чекатиме на усі процеси замість виведення їхнього списку до stdout.
ПАРАМЕТРИ
-сигнал
--signal
сигнал
Визначає сигнал, який слід надіслати кожному відповідному процесу. Можна скористатися числовим значенням або символічною назвою сигналу. У режимі pgrep або pidwait можна використовувати лише довгу версію параметра. У цьому режимі параметр не працює, якщо не використано у поєднанні із --require-handler для фільтрування процесів із наявним обробником певного сигналу у просторі користувача.
-c, --count
Придушити звичайне виведення. Замість цього, вивести кількість відповідних процесів. Якщо не вдасться знайти нічого, наприклад, буде повернуто нульове значення, програма поверне ненульове значення помилки. Зауважте, що для pkill і pidwait кількість є кількістю відповідних процесів, а не кількістю процесів, яким було успішно надіслано сигнал, або кількість процесів, на які очікувала програма.
-d, --delimiter роздільник
Встановлює рядок, що використовуватиметься для відокремлення ідентифікаторів процесів у виведених даних (типовим роздільником є символ розриву рядка). (Лише pgrep.)
-e, --echo
Показати назву і PID процесів, роботу яких буде завершено (лише pkill).
-f, --full
Зазвичай, відповідність взірця встановлюється лише для назви процесу. Якщо використано -f, відповідність встановлюється за цілим рядком команди.
-g, --pgroup група процесів,...
Встановлювати відповідність процесів лише для вказаного списку ідентифікаторів груп. Група процесів 0 відповідає власній групі процесів pgrep, pkill або pidwait.
-G, --group gid,...
Встановлювати відповідність процесів зі списку справжніх ідентифікаторів груп. Можна використовувати цифрове або символічне значення ідентифікатора.
-i, --ignore-case
Виконувати пошук процесів без врахування регістру символів.
-l, --list-name
Вивести список назв процесів, а також ідентифікаторів процесів. (Лише pgrep.)
-a, --list-full
Вивести список рядків команд повністю, а також ідентифікаторів процесів. (Лише pgrep.)
-n, --newest
Вибрати лише найновіші (запущені якомога пізніше) відповідні процеси.
-o, --oldest
Вибрати лише найдавніші (запущені якомога раніше) відповідні процеси.
-O, --older секунди
Вибрати процеси, які є старішими за вказану кількість секунд.
-P, --parent ppid,...
Встановлювати відповідність лише тих процесів, які мають батьківські процеси зі вказаного списку.
-s, --session sid,...
Встановлювати відповідність лише тих процесів, які мають ідентифікатори сеансів процесів зі вказаного списку. Ідентифікатор 0 відповідає ідентифікаторам сеансів самих програм pgrep, pkill або pidwait.
-t, --terminal термінал,...
Встановлювати відповідність лише процесів із терміналом керування із вказаного списку. Назву термінала слід вказувати без префікса «/dev/».
-u, --euid euid,...
Встановлювати відповідність процесів зі списку ідентифікаторів ефективних користувачів. Можна використовувати цифрове або символічне значення ідентифікатора.
-U, --uid uid,...
Встановлювати відповідність процесів зі списку справжніх ідентифікаторів користувачів. Можна використовувати цифрове або символічне значення ідентифікатора.
-v, --inverse
Інвертує відповідність. Зазвичай, цей параметр використовується у контексті pgrep або pidwait. У контексті pkill скорочену форму параметра вимкнено для того, щоб запобігти випадковому використанню цього параметра.
-w, --lightweight
Показує усіх ідентифікатори потоків обробки, замість ідентифікаторів, у контексті pgrep або pidwait. У контексті pkill цей параметр вимкнено.
-x, --exact
Встановлювати відповідність лише процесів, назви яких (або рядки команд, якщо вказано параметр -f) точно відповідає взірцю.
-F, --pidfile файл
Прочитати PID з файла. Ймовірно, цей параметр корисніший для pkill або pidwait, а не для pgrep.
-L, --logpidfile
Завершувати роботу повідомленням про помилку, якщо pid-файл (див. -F) не заблоковано.
-r, --runstates D,R,S,Z,...
Виконати пошук лише тих процесів, які відповідають вказаному значенню стану процесу.
-A, --ignore-ancestors
Ігнорувати усі попередники pgrep, pkill та pidwait. Наприклад, це може бути корисним при розширенні прав доступу за допомогою sudo або подібних інструментів.
-H, --require-handler
Встановлювати відповідність лише тих процесів, які мають обробник сигналу, який має бути надіслано, у просторі користувача.
--cgroup назва,...
Встановити відповідність наданій назві групи керування (cgroup) у версії 2. Див. cgroups(8)
--ns pid
Встановлювати відповідність процесів, які належать до одного простору назв. Для встановлення відповідності для процесів інших користувачів програму має бути запущено від імені користувача root. Див. довідку щодо --nslist, щоб дізнатися про те, як обмежити перелік відповідних просторів назв.
--nslist назва,...
Встановлювати відповідність лише для вказаних просторів назв. Можливі простори назв: ipc, mnt, net, pid, user, uts.
-q, --queue значення
Скористайтеся kill(2) замість sigqueue(3), і аргумент значення, який використовується для задання цілого значення, буде надіслано разом із сигналом. Якщо у процесі, який його отримає, встановлено обробки сигналу, який використовує прапорець SA_SIGINFO sigaction(2), процес зможе отримати ці дані за допомогою поля si_value структури siginfo_t.
-V, --version
Вивести дані щодо версії і завершити роботу.
-h, --help
Показати довідкові дані і завершити роботу.
ОПЕРАНДИ
взірець
Вказує розширений формальний вираз для відповідності за назвами процесів або рядками команд.
ПРИКЛАДИ
Приклад 1: знайти ідентифікатор процесу фонової служби named:
$ pgrep -u root named
Приклад 2: змусити syslog виконати повторне читання файла налаштувань:
$ pkill -HUP syslogd
Приклад 3: надати докладну інформацію щодо усіх процесів xterm:
$ ps -fp $(pgrep -d, -x xterm)
Приклад 4: підвищити пріоритетність усіх процесів chrome:
$ renice +4 $(pgrep chrome)
СТАН ВИХОДУ
0 |
Вказаному критерію відповідає один або декілька процесів. Для pkill і pidwait також має бути один або декілька процесів, яким успішно надіслано сигнал або які перебувають у стані очікування. | ||
1 |
Не знайдено жодного відповідного процесу або жодному зі знайдених процесів не вдалося надіслати сигнал. | ||
2 |
Синтаксична помилка у рядку команди. | ||
3 |
Критична помилка: вичерпано пам’ять тощо. |
ЗАУВАЖЕННЯ
Назву процесу, що використовується для встановлення відповідності, обмежено 15 символами, які виводить /proc/pid/stat. Для встановлення відповідності за цілим командним рядком, /proc/pid/cmdline, скористайтеся параметром -f. Потоки обробки можуть не мати такої самої назви процесу, що і батьківський процес, але матимуть той самий рядок команди.
Запущений процес pgrep, pkill або pidwait ніколи не повідомлятиметься самим собою як відповідник.
Використання параметра -O --older буде без повідомлень не враховано, якщо /proc змонтовано з параметром subset=pid.
ВАДИ
Не можна одночасно використовувати параметри -n, -o та -v одночасно. Повідомте авторам, якщо вам потрібне таке поєднання.
Програма повідомляє про щезлі процеси.
pidwait потребує системного виклику pidfd_open(2), який вперше з’явився у Linux 5.3.
ТАКОЖ ПЕРЕГЛЯНЬТЕ
ps(1), regex(7), signal(7), sigqueue(3), killall(1), skill(1), kill(1), kill(2), cgroups(8).
АВТОР
kjetilho [AT] ifi.no">Kjetil Torgrim Homme
Як надіслати звіт про вади
Про вади, будь ласка, повідомляйте на адресу procps [AT] freelists.org">procps [AT] freelists.org