Перейти до змісту

Розширені команди для користувачів Linux

Розширені команди забезпечують більше налаштувань і елементів керування в більш спеціалізованих ситуаціях, коли ви ознайомитеся з основними командами.


Цілі: у цьому розділі майбутні адміністратори Linux дізнаються про:

✔ деякі корисні команди, не описані в попередньому розділі.
✔ деякі додаткові команди.

🏁 Команди користувача, Linux

Знання: ⭐
Складність: ⭐ ⭐ ⭐

Час читання: 20 хвилин


Команда uniq

Команда uniq є дуже потужною командою, яка використовується з командою sort, особливо для аналізу файлів журналу. Це дозволяє сортувати та відображати записи, видаляючи дублікати.

Щоб проілюструвати, як працює команда uniq, скористаємося файлом firstnames.txt, який містить список імен:

antoine
xavier
steven
patrick
xavier
antoine
antoine
steven

Примітка

uniq вимагає, щоб вхідний файл був відсортований перед запуском, оскільки він порівнює лише послідовні рядки.

Без аргументів команда uniq не відображатиме ідентичні рядки, які слідують один за одним у файлі firstnames.txt:

$ sort firstnames.txt | uniq
antoine
patrick
steven
xavier

Щоб відобразити лише ті рядки, які з’являються лише один раз, скористайтеся параметром -u:

$ sort firstnames.txt | uniq -u
patrick

І навпаки, щоб відобразити лише ті рядки, які з’являються у файлі щонайменше двічі, скористайтеся параметром -d:

$ sort firstnames.txt | uniq -d
antoine
steven
xavier

Щоб просто видалити рядки, які з’являються лише один раз, скористайтеся опцією -D:

$ sort firstnames.txt | uniq -D
antoine
antoine
antoine
steven
steven
xavier
xavier

Нарешті, щоб підрахувати кількість входжень кожного рядка, використовуйте параметр -c:

$ sort firstnames.txt | uniq -c
      3 antoine
      1 patrick
      2 steven
      2 xavier
$ sort firstnames.txt | uniq -cd
      3 antoine
      2 steven
      2 xavier

Команда xargs

Команда xargs дозволяє створювати та виконувати командні рядки зі стандартного введення.

Команда xargs зчитує зі стандартного вводу аргументи, розділені пробілами або переводами рядків, і виконує команду (за замовчуванням /bin/echo) один або кілька разів, використовуючи початкові аргументи, за якими йдуть аргументи, прочитані зі стандартного введення.

Першим і найпростішим прикладом може бути наступне:

$ xargs
use
of
xargs
<CTRL+D>
use of xargs

Команда xargs очікує введення зі стандартного введення stdin. Введено три рядки. Кінець введення користувача вказується в xargs послідовністю натискань клавіш CTRL+D. Потім xargs виконує команду за замовчуванням echo, за якою слідують три аргументи, що відповідають введеним користувачам, а саме:

$ echo "use" "of" "xargs"
use of xargs

Можна вказати команду, яку буде виконувати xargs.

У наступному прикладі xargs виконає команду ls -ld для набору папок, указаних у стандартному вводі:

$ xargs ls -ld
/home
/tmp
/root
<CTRL+D>
drwxr-xr-x. 9 root root 4096  5 avril 11:10 /home
dr-xr-x---. 2 root root 4096  5 avril 15:52 /root
drwxrwxrwt. 3 root root 4096  6 avril 10:25 /tmp

На практиці команда xargs виконала команду ls -ld /home /tmp /root.

Що станеться, якщо команда, яку потрібно виконати, не приймає кілька аргументів, як команда find?

$ xargs find /var/log -name
*.old
*.log
find: paths must precede expression: *.log

Команда xargs намагалася виконати команду find із кількома аргументами за параметром -name, що спричинило find створення помилки:

$ find /var/log -name "*.old" "*.log"
find: paths must precede expression: *.log

У цьому випадку командою xargs потрібно примусово виконати команду find кілька разів (один раз на рядок, введений як стандартний ввід). Параметр -L із наступним цілим числом дозволяє вказати максимальну кількість записів, які потрібно обробити командою одночасно:

$ xargs -L 1 find /var/log -name
*.old
/var/log/dmesg.old
*.log
/var/log/boot.log
/var/log/anaconda.yum.log
/var/log/anaconda.storage.log
/var/log/anaconda.log
/var/log/yum.log
/var/log/audit/audit.log
/var/log/anaconda.ifcfg.log
/var/log/dracut.log
/var/log/anaconda.program.log
<CTRL+D>

Щоб вказати обидва аргументи в одному рядку, скористайтеся параметром -n 1:

$ xargs -n 1 find /var/log -name
*.old *.log
/var/log/dmesg.old
/var/log/boot.log
/var/log/anaconda.yum.log
/var/log/anaconda.storage.log
/var/log/anaconda.log
/var/log/yum.log
/var/log/audit/audit.log
/var/log/anaconda.ifcfg.log
/var/log/dracut.log
/var/log/anaconda.program.log
<CTRL+D>

Приклад резервного копіювання за допомогою tar на основі пошуку:

$ find /var/log/ -name "*.log" -mtime -1 | xargs tar cvfP /root/log.tar
$ tar tvfP /root/log.tar
-rw-r--r-- root/root      1720 2017-04-05 15:43 /var/log/boot.log
-rw-r--r-- root/root    499270 2017-04-06 11:01 /var/log/audit/audit.log

Особливістю команди xargs є те, що вона розміщує вхідний аргумент у кінці викликаної команди. Це дуже добре працює з наведеним вище прикладом, оскільки передані файли формуватимуть список файлів, які потрібно додати до архіву.

Використовуючи приклад команди cp, щоб скопіювати список файлів у каталозі, цей список файлів буде додано в кінці команди... але що команда cp</ code> очікує в кінці команди призначення. Щоб зробити це, скористайтеся опцією <code>-I, щоб розмістити вхідні аргументи не в кінці рядка.

$ find /var/log -type f -name "*.log" | xargs -I % cp % /root/backup

Параметр -I дозволяє вказати символ (символ % у наведеному вище прикладі), куди будуть розміщені вхідні файли для xargs.

Пакет yum-utils

Пакет yum-utils — це набір утиліт, створених для yum різними авторами, які роблять його зручнішим і потужнішим у використанні.

Примітка

Хоча yum було замінено на dnf у Rocky Linux 8, назва пакета залишилася yum-utils, хоча його також можна встановити як dnf-utils. Це класичні утиліти YUM, реалізовані як прокладки CLI поверх DNF для підтримки зворотної сумісності з yum-3.

Ось кілька прикладів цих утиліт:

  • Команда repoquery

Команда repoquery використовується для запиту пакетів у сховищі.

Приклади використання:

  • Відображення залежностей пакета (це може бути пакет програмного забезпечення, який було встановлено або не встановлено), еквівалентно dnf deplist <package-name>

    repoquery --requires <package-name>
    

  • Відображення файлів, які були надані встановленим пакетом (не працює для пакетів, які не встановлено), еквівалентно rpm -ql <package-name>

    $ repoquery -l yum-utils
    /etc/bash_completion.d
    /etc/bash_completion.d/yum-utils.bash
    /usr/bin/debuginfo-install
    /usr/bin/find-repos-of-install
    /usr/bin/needs-restarting
    /usr/bin/package-cleanup
    /usr/bin/repo-graph
    /usr/bin/repo-rss
    /usr/bin/repoclosure
    /usr/bin/repodiff
    /usr/bin/repomanage
    /usr/bin/repoquery
    /usr/bin/reposync
    /usr/bin/repotrack
    /usr/bin/show-changed-rco
    /usr/bin/show-installed
    /usr/bin/verifytree
    /usr/bin/yum-builddep
    /usr/bin/yum-config-manager
    /usr/bin/yum-debug-dump
    /usr/bin/yum-debug-restore
    /usr/bin/yum-groups-manager
    /usr/bin/yumdownloader
    …
    
  • Команда yumdownloader:

Команда yumdownloader завантажує пакети RPM зі сховищ. Еквівалент dnf download --downloadonly --downloaddir ./ package-name

Примітка

Ця команда дуже корисна для швидкого створення локального сховища з кількома обертами за хвилину!

Приклад: yumdownloader завантажить пакет rpm samba та всі його залежності:

$ yumdownloader --destdir /var/tmp --resolve samba
or
$ dnf download --downloadonly --downloaddir /var/tmp  --resolve  samba
Опції Коментарі
--destdir Завантажені пакети будуть збережені у вказаній папці.
--resolve Також завантажує залежності пакетів.

Пакети psmisc

Пакет psmisc містить утиліти для керування системними процесами:

  • pstree: команда pstree відображає поточні процеси в системі у вигляді дерева.
  • killall: команда killall надсилає сигнал завершення всім процесам, визначеним за назвою.
  • fuser: команда fuser визначає PID процесів, які використовують вказані файли або файлові системи.

Приклади:

$ pstree
systemd─┬─NetworkManager───2*[{NetworkManager}]
        ├─agetty
        ├─auditd───{auditd}
        ├─crond
        ├─dbus-daemon───{dbus-daemon}
        ├─firewalld───{firewalld}
        ├─lvmetad
        ├─master─┬─pickup
        │        └─qmgr
        ├─polkitd───5*[{polkitd}]
        ├─rsyslogd───2*[{rsyslogd}]
        ├─sshd───sshd───bash───pstree
        ├─systemd-journal
        ├─systemd-logind
        ├─systemd-udevd
        └─tuned───4*[{tuned}]
# killall httpd

Kill процеси (параметр -k), які мають доступ до файлу /etc/httpd/conf/httpd.conf:

# fuser -k /etc/httpd/conf/httpd.conf

Команда watch

Команда watch регулярно виконує команду та відображає результат у терміналі на весь екран.

Параметр -n дозволяє вказати кількість секунд між кожним виконанням команди.

Примітка

Щоб вийти з команди watch, ви повинні ввести клавіші: CTRL+C щоб вбити процес.

Приклади:

  • Відображати кінець файлу /etc/passwd кожні 5 секунд:
$ watch -n 5 tail -n 3 /etc/passwd

Результат:

Every 5.0s: tail -n 3 /etc/passwd                                                                                                                                rockstar.rockylinux.lan: Thu Jul  1 15:43:59 2021

sssd:x:996:993:User for sssd:/:/sbin/nologin
chrony:x:995:992::/var/lib/chrony:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
  • Контроль кількості файлів у папці:
$ watch -n 1 'ls -l | wc -l'
  • Показати годинник:
$ watch -t -n 1 date

Востаннє оновлено: July 4, 2023