Faq — различия между версиями
Vaal (обсуждение | вклад) (Отредактировал страницу) |
Vaal (обсуждение | вклад) |
||
Строка 425: | Строка 425: | ||
#file /bin/pidof | #file /bin/pidof | ||
/bin/pidof: symbolic link to `../sbin/killall5' | /bin/pidof: symbolic link to `../sbin/killall5' | ||
+ | </source> | ||
+ | |||
+ | === <p style="text-align:center"><span style="color:red">'''Быстрое копирование данных при помощи Python'''</span></p> === | ||
+ | <p style="text-align:left">Иногда необходимо быстро предоставить доступ к файлам на машине Linux. В случае, если на такой машине имеется установленный python, то можно запустить простой HTTP-сервер, который предоставит такой доступ(на порту 8080): | ||
+ | </p> | ||
+ | <source lang="python"> | ||
+ | $ python -m SimpleHTTPServer 8080 | ||
+ | </source> | ||
+ | <p style="text-align:left"> | ||
+ | или таким образом: | ||
+ | </p> | ||
+ | <source lang="python"> | ||
+ | $ python3 -m http.server 8080 | ||
</source> | </source> | ||
Версия 12:53, 4 апреля 2023
Отличие обычного пользователя Linux от профессионала заключается во времени, проведённом за изучением хитростей и приёмов, которые позволяют решать не быстрые задачи в одно мгновение. Если вы хотите увеличить скорость работы без долгого набивания шишек в консоли, здесь приводится список лёгких для изучения приёмов. Они помогут сделать вашу работу эффективной и менее трудозатратной.
Содержание
- 1 Список не ваших процессов
- 2 Замена текста в файлах
- 3 Исправить консоль
- 4 Запуск множественных X-сессий
- 5 Лёгкое резервное копирование
- 6 Поиск самых больших файлов в текущей директории
- 7 Оптимизация баз данных MySQL
- 8 Список открытых портов
- 9 Поиск занятых устройств
- 10 Поиск изменённых сегодня файлов
- 11 Поиск больших файлов в Linux
- 12 Определить дату установки Linux
- 13 Очистка КЭШа оперативной памяти в Linux
- 14 Проверка количества открытых файлов для процесса
- 15 Просмотреть краткую информацию по сетевому интерфейсу
- 16 Подсчитать Количество Файлов(Директорий) в Папке
- 17 Настройка ssh на авторизацию по ключам
- 18 Ошибка "Broken pipe" при авторизации пользователя по ssh
- 19 Копирование директорий на удалённый сервер используя tar, ssh, cat или dd
- 20 Работа с процессами
- 21 Быстрое копирование данных при помощи Python
- 22 Ссылки
Список не ваших процессов
Для получения списка всех процессов, запущенных не текущим пользователем, выполните команду:
$ps aux | grep -v `whoami`
Для получения списка из 10 процессов, которые сильнее всего загружают систему, выполните команду:
$ps aux --sort=-%cpu | grep -m 11 -v `whoami`
Замена текста в файлах
Если надо заменить текст не в одном файле, то имеется несколько способов. Для того, чтобы заменить текст «Windows» на «Linux» во всех файлах в текущей директории, название которой начинается с «test», введите в консоли(необходим интерпретатор perl):
$perl -i -pe 's/Windows/Linux/;' test*
Чтобы провести ту же операцию во всех поддиректориях:
$find. -name '*.txt' -print | xargs perl -pi -e's/Windows/Linux/ig' *.txt
Если Вы хотите сделать то же самое для на обычных файлов со множеством переносов строк и странных символов (файл — в другой кодировке):
$find -type f -name '*.txt' -print0 | xargs --null perl -pi -e 's/Windows/Linux/
Исправить консоль
Если использовать команду less или cat для просмотра файла, в конце которого — бинарные данные, то можно легко испортить консоль. Потому что в бинарных данных могут попасться любые сочетания управляющих кодов: компьютер будет издавать звуки «бип-бип», появятся прикольные символы, странные цветовые сочетания. В конце концов, шрифт изменится на какие-то иероглифы. Bash, очевидно, продолжает работать, но вы ничего не можете прочитать и сделать. Просто наберите в консоли команду инициализации:
$reset
Запуск множественных X-сессий
Если надо дать кому-нибудь доступ к Вашему компьютеру, то вы откроете для себя, что это не всегда необходимо. Если предположить, что компьютер стартует в графическом режиме (runlevel 5), то, одновременно нажав Ctrl+Alt+<F7>, вы попадете в консоль. Введите логин и пароль, потом исполните следующий код:
$startx -- :1
чтобы войти в графическое окружение. Чтобы вернуться в предыдущую сессию, нажмите Ctrl+Alt+<F7>, для ещё одного возврата — Ctrl+Alt+<F8>. Вы можете этот трюк: клавиши с F1 по F6 отвечают за 6 сессий консоли, а клавиши с F7 по F12 — за 6 Х-сессий. Подводный камень: в разных дистрибутивах могут использоваться разные сочетания клавиш.
Лёгкое резервное копирование
Если надо сделать резервную копию папки и скопировать только изменившиеся файлы, то можно использовать для этого rsync (вам нужен аккаунт на удалённом компьютере):
$rsync -vare ssh jono@192.168.0.2:/home/jono/importantfiles/* /home/jono/backup/
Поиск самых больших файлов в текущей директории
Можно столкнуться с проблемой, когда надо удалить несколько больших файлов. Их можно найти в текущей директории с помощью команды:
$ls -lSrh
Ключ “r” означает, что большие файлы должны выводиться в конце. Следующей командой можно найти самые большие файлы MP3/MPEG:
$ls -lSrh *.mp*
Также можно найти самые большие директории:
$du -kx | egrep -v "\./.+/" | sort -n
Оптимизация баз данных MySQL
При любом изменении структуры базы данных или удалении больших объёмов данных, файлы могут стать фрагментированными, что приводит к потере производительности. Просто запомните простое правило — запускать оптимизатор базы при любом изменении базы:
#mysqloptimize -A -u<username> -p<password> #mysqlcheck --optimize -A -u<username> -p<password>
Список открытых портов
Получить список открытых портов в состоянии Listen в Linux очень просто, для этого достаточно выполнить:
#netstat -lnp Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 0.0.0.0:5280 0.0.0.0:* LISTEN 698/perl tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 217/httpd tcp 0 0 10.42.3.2:53 0.0.0.0:* LISTEN 220/named tcp 0 0 10.42.4.6:53 0.0.0.0:* LISTEN 220/named tcp 0 0 127.0.0.1:53 0.0.0.0:* LISTEN 220/named tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 200/sshd udp 0 0 0.0.0.0:32768 0.0.0.0:* 220/named udp 0 0 10.42.3.2:53 0.0.0.0:* 220/named udp 0 0 10.42.4.6:53 0.0.0.0:* 220/named udp 0 0 127.0.0.1:53 0.0.0.0:* 220/named udp 0 0 0.0.0.0:67 0.0.0.0:* 222/dhcpd raw 0 0 0.0.0.0:1 0.0.0.0:* 7 222/dhcpd
В этом примере видно, что процесс с PID'ом 698 — процесс интерпретатора Perl, который слушает порт 5280. Если вы не root в системе, то система не покажет пути к программам.
Поиск занятых устройств
Вы наверняка сталкивались с ситуацией, когда надо отмаунтить диск, но система при попытке отключения сообщает о том, что он занят. Одной командой можно узнать, какое приложение использует его:
#lsof +D /mnt/windows
Она показывает PID и команду запуска любого процесса, использующего /mnt/windows.
Поиск изменённых сегодня файлов
Например, утром вы создали файл, который именно сейчас очень нужен. Однако, вы не можете вспомнить его название. Вручную перебирать домашнюю директорию бессмысленно, где скопилась не одна тысяча файлов. Но есть небольшой приём, показывающий эффективность пайпов и объединения нескольких команд консоли:
#ls -al --time-style=+%D | grep `date +%D`
Параметры команды ls требуют вывода даты в определенном формате. Хитрость в том: то, что выдаст ls, идет на вход grep. Параметр grep сами по себе команда (заключена в обратные апострофы), которая подставляет текущую дату в шаблон для отсева. Её легко модифицировать для поиска по другим датам, размеру файла и т.д.
Поиск больших файлов в Linux
Поиск больших файлов особенно актуален когда на диске заканчивается место и приходится искать кандидатов на удаление. Самый лучший способ чтобы найти все самые большие файлы на хосте с Linux - воспользоваться командной строкой. В принципе не существует простой команды для поиска самых больших файлов в Linux. Однако, можно с лёгкостью получить список самых больших файлов, используя комбинацию нескольких простых команд.Выполните следующую комбинацию команд для поиска десяти самых больших файлов в Linux, начиная с директории <DIR> (измените <DIR> на директорию в которой Вы хотите запустить поиск):
#find <DIR> -mount -type f -ls 2> /dev/null | sort -rnk7 | head -10 | awk '{printf "%10d MB\t%s\n",($7/1024)/1024,$NF}' 106 MB /var/lib/mysql/ibdata1 94 MB /usr/lib/locale/locale-archive 41 MB /scripts/20130206-015833.tar.gz 41 MB /scripts/20130206-004839.tar.gz 41 MB /scripts/20130206-130400.tar.gz 41 MB /scripts/20130206-000442.tar.gz 41 MB /scripts/20130206-132019.tar.gz 41 MB /root/20130208-133954.tar.gz 33 MB /var/log/messages-20130303 32 MB /var/lib/rpm/Packages
Найти 10 самых больших фалов, начиная с '/home'
#find /home -mount -type f -ls 2> /dev/null | sort -rnk7 | head -10 | awk '{printf "%10d MB\t%s\n",($7/1024)/1024,$NF}' 3007 MB /home/user/Desktop/share/linux-65835.iso 448 MB /home/user/Pictures/Turkey/SAM_4590.AVI 266 MB /home/user/Pictures/Turkey/SAM_4588.AVI 173 MB /home/user/Camera/VID_20130909_120713.mp4 152 MB /home/user/Camera/VID_20130909_115427.mp4 133 MB /home/user/Camera/VID_20130909_210904.mp4 133 MB /home/user/Pictures/Paris/VID_20130928_182431.mp4 131 MB /home/user/Pictures/Turkey/SAM_4597.AVI 129 MB /home/user/Pictures/Turkey/SAM_4641.AVI 127 MB /home/user/Desktop/tmp/Camera/VID_20130911_164440.mp4
Сортировка вывода по размеру файлов командой du
:
#du -k /opt/ruby_projects/* | sort -nr | cut -f2 | xargs -d '\n' du -sh
Определить дату установки Linux
Есть несколько вариантов узнать дату и время установки:
#ls -clt / | tail -n 1 | awk '{ print $7, $6, $8 }' #tune2fs -l /dev/sda1 | grep create #LC_TIME="en_DK" rpm -qia |grep "Install Date"|awk '{print $3}'|uniq |sort -r|tail -n 1
Очистка КЭШа оперативной памяти в Linux
Для того, чтобы посмотреть сколько оперативной памяти занято и сколько закешировано в данный момент, можно воспользоваться командой free
. С параметром -g она выведет информацию об использовании памяти в гигабайтах, с параметром -m в мегабайтах:
#free -g
Для очистки кеша страниц(pagecache) использовать команду:
#echo 1 > /proc/sys/vm/drop_caches
Для очистки directory entry(dentries) и index node(inode) использовать команду:
#echo 2 > /proc/sys/vm/drop_caches
Для очистки кеша страниц(pagecache), directory entry(dentries) и index node(inode) использовать команду:
#echo 3 > /proc/sys/vm/drop_caches
Проверка количества открытых файлов для процесса
В примере ниже описана команда получения количества открытых процессом файлов, для процесса line4:
#for pid in `pidof line4`; do echo "$(< /proc/$pid/cmdline)"; egrep 'files|Limit' /proc/$pid/limits; \ echo "Currently open files: $(ls -1 /proc/$pid/fd | wc -l)"; echo; done
Вывод представлен на скриншоте ниже:
Просмотреть краткую информацию по сетевому интерфейсу
Для просмотра выполнить команду:
#ip addr show <NIC> | grep inet | awk '{ print $2; }' | sed 's/\/.*$//'
Подсчитать Количество Файлов(Директорий) в Папке
Ниже приведены лучшие способы поиска и подсчета количества файлов и папок в конкретной директории.
Подсчитать количество файлов в текущей папке:
- Если Вам необходимо подсчитать довольно большое количество файлов, данный метод является самым быстрым:
#ls -f . | wc -l #find . -type f -maxdepth 1 | wc -l
- Команда рекурсивно считает количество файлов в текущей директории и всех её поддиректориях:
#find . -type f | wc -l
- Команда рекурсивно считает количество папок в текущей директории и всех её поддиректориях:
#find . -type d | wc -l
- Команда рекурсивно считает количество файлов с расширением ".txt" в текущей директории и всех её поддиректориях:
#find . -type f -name "*.txt" | wc -l
Настройка ssh на авторизацию по ключам
Бывают случаи, когда необходимо настроить ssh c доступом к серверам с использованием авторизации по ключам. Для этого необходимо выполнить следующие команды(на сервере с которого планируются подключения к серверам, используя ключи):
Переходим в директорию .ssh, расположенную в домашней директории пользователя:
#cd ~/.ssh/
Генерируем ключи, которые будем передавать. На все вопросы нажимаем клавишу Enter:
#ssh-keygen
Отправляем на сервер 192.168.1.21 содержимое ~/.ssh/id_rsa.pub в файл /home/user/.ssh/authorized_keys:
#cat ~/.ssh/id_rsa.pub | ssh user@192.168.1.21 'cat >> .ssh/authorized_keys'
Отправляем на сервер 192.168.1.21 команду, которая выставит права записи и чтения на файл authorized_keys только для владельца:
#ssh user@192.168.1.21 'chmod 600 ~/.ssh/authorized_keys'
Отправляем на сервер 192.168.1.21 команду, которая выставит права записи и чтения и исполнения на директорию .ssh только для владельца:
#ssh user@192.168.1.21 'chmod 700 ~/.ssh'
Вводим данную команду, для проверки, что авторизации по ключам работает:
#ssh user@192.168.1.21
Следует учитывать, что на домашнюю директорию пользователя и директорию .ssh(/home/<username>/.ssh) на удалённом сервере должны быть выставлены права drwx------(700), а на файл /home/<username>/.ssh/authorized_keys -rw-------(600).
Ошибка "Broken pipe" при авторизации пользователя по ssh
Бывают случаи, когда при авторизации обычным пользователем по ssh появляется ошибка "Broken pipe". При этом авторизация под root может проходить успешно. Если из-под root выполнить команду su - <username> и получить результат "su: cannot set user id: Resource temporarily unavailable" или "su:невозможно установить пользовательский id: Ресурс временно недоступен", то надо посмотреть в сторону того, какое кол-во процессов разрешено запускать пользователю и какое кол-во процессов из-под этого пользователя запущенно на данный момент. Для этого необходимо выполнить следующие команды:
Команда покажет сколько процессов запущено от пользователя <username> на данный момент:
#ps -eLF|grep '<username>'|wc -l
Команда покажет сколько файлов открыто от пользователя <username> на данный момент:
#lsof -u '<username>'|wc -l
Команда покажет сколько процессов разрешено запускать пользователям(* - любой пользователь) в RHEL 6.x/CentOS 6.x:
#cat /etc/security/limits.d/90-nproc.conf
Команда покажет сколько процессов разрешено запускать пользователям(* - любой пользователь) в RHEL 7.x/CentOS 7.x:
#cat /etc/security/limits.d/20-nproc.conf
#ps -eLF|grep '<username>'|wc -l
#sysctl -p
Копирование директорий на удалённый сервер используя tar, ssh, cat или dd
Архивирование директории на удалённый сервер с использованием cat:
# tar zcvfp - /home/user/sourcedir | ssh user@remote_host "cat > ~/from_somehost.tar.gz"
То, что tar выведет на стандартный вывод, перенаправляется на удалённый сервер (user@remote_host), где и запускается команда "cat > ~/from_somehost.tar.gz". cat принимает на вход то, что выдал tar, а затем всё это складывает в файл ~/from_somehost.tar.gz.
Архивирование директории на удалённый сервер с dd:
#tar zcvfp - /home/user/sourcedir | ssh user@remote_host "dd of=~/from_somehost.tar.gz"
В этом примере вместо cat используется dd (disk destroy ;), у которой есть параметр of (output file), то есть тот, куда нужно складывать то, что пришло от tar. Остальное по аналогии должно быть понятно.
Архивирование с удалённой машины на локальную с использованием cat:
#ssh user@remote_host "tar zcvfp - /home/user/sourcedir" | cat > ~/from_somehost.tar.gz
Архивирование с удалённой машины на локальную с использованием dd:
#ssh user@remote_host "tar zcvfp - /home/user/sourcedir" | dd of=~/from_somehost.tar.gz
Распаковка удалённого архива на локальную машину:
#ssh user@remote_host "cat /home/user/from_somehost.tar.gz" |tar xvfp -
Работа с процессами
Часто бывает полезным узнать разного рода параметры уже запущенных процессов, а так же манипулировать ими. Рассмотрим несколько разных примеров по работе с процессами.
Много информации нам предоставляет файловая система procfs.
procfs — виртуальная файловая система, используемая в UNIX-like ОС. procfs позволяет получить доступ к информации о системных процессах из ядра, она необходима для выполнения таких команд как ps, w, top. Обычно её монтируют на /proc. procfs создаёт двухуровневое представление пространств процессов. На верхнем уровне процессы представляют собой директории, именованные в соответствии с их pid.
Некоторые файлы и директории из ProcFS, где PID – идентификатор процесса или self:
- /proc/PID/cmdline – аргументы командной строки;
- /proc/PID/environ – переменные окружения для данного процесса;
- /proc/PID/status – статус процесса;
- /proc/PID/fd – директория, содержащая символьные ссылки на каждый открытый файловый дескриптор;
- /proc/cpuinfo – информация о процессоре (производитель, модель, поколение и т.п.);
- /proc/cmdline – параметры, передаваемые ядру при загрузке;
- /proc/uptime – количество секунд, прошедших с момента загрузки ядра и проведенных в режиме бездействия;
- /proc/version – содержит информацию о версии ядра, компилятора и другую информацию, связанную с загруженным ядром.
Посмотрев на размер файлов в каталоге /proc, можно увидеть, что они все нулевого размера. Дело в том, что в действительности все эти файлы не существуют. Примеры использования procfs:
1) Текущий рабочий каталог процесса:
# ls -la /proc/3165/cwd lrwxrwxrwx 1 clamav clamav 0 Авг 18 16:07 /proc/3165/cwd -> /var/lib/clamav
где 3165 — номер pid’a процесса.
2) Вывести все переменные процесса:
# cat /proc/2361/environ | strings XDG_SESSION_ID=1 TERM=xterm SHELL=/bin/bash SSH_CLIENT=10.0.2.2 1383 22 SSH_TTY=/dev/pts/0 USER=vaal LS_COLORS=rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32: *.tar=01;31:*.tgz=01;31:*.arc=01;31:*.arj=01;31:*.taz=01;31:*.lha=01;31:*.lz4=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.tzo=01;31:*.t7z=01;31: *.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.lrz=01;31:*.lz=01;31:*.lzo=01;31:*.xz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31: *.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.alz=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31: *.cab=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35: *.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.webm=01;35:*.ogm=01;35:*.mp4=01;35: *.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35: *.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.axv=01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=00;36:*.au=00;36: *.flac=00;36:*.m4a=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.axa=00;36:*.oga=00;36: *.spx=00;36:*.xspf=00;36: DOCKER_TLS_VERIFY=0 MAIL=/var/mail/vaal PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games PWD=/home/vaal LANG=ru_RU.UTF-8 SHLVL=1 HOME=/home/vaal LOGNAME=vaal SSH_CONNECTION=10.0.2.2 1383 10.0.2.15 22 LESSOPEN=| /usr/bin/lesspipe %s XDG_RUNTIME_DIR=/run/user/1000 LESSCLOSE=/usr/bin/lesspipe %s %s _=/usr/bin/mc
3) Удалили файл, используемый процессом. Как восстановить файл?:
Попробовать поискать файл в каталоге /proc/PID/fd Почему так можно делать? Всё дело в том, что при удалении файла, который всё-таки открыт процессом, файл перестал быть виден в файловой системе, но не исчез, и окончательно удалён он будет только когда закроется последний ссылающийся на него дескриптор. Каталог /proc/PID/fd содержит символьные ссылки на все открытые процессом PID дескрипторы.
4) Связь между /proc и sysctl(взято с Linux-center):
Sysctl использует файлы в /proc/sys как индивидуальные переменные, которые могут быть изменены. К примеру, файл в /proc/sys, который представляет максимальное количество заголовков файлов в системе, /proc/sys/fs/file-max, представлен как fs.file-max. Этот пример требует некоторых дополнительных пояснений в записи sysctl. Так как sysctl может только изменять переменные в директории /proc/sys, то часть имени переменной обозначающая директорию отбрасывается. Другое изменение касается слэшей, которые заменяются на точки. Вот два простых правила для преобразования файлов в /proc/sys и переменных в sysctl:
- Отбросьте /proc/sys от начала.
- Замените слэши на точки в имени файла.
Эти два правила позволят вам преобразовать любой файл в /proc/sys в любое имя переменной в sysctl. Обычное преобразование имени файла в переменную:
/proc/sys/dir/file --> dir.file dir1.dir2.file --> /proc/sys/dir1/dir2/file
Можно отобразить все переменные, доступные для изменения, используя команду sysctl -a. Переменные могут также быть изменены с помощью sysctl, которая выполняет ту же работу что и echo. Эта запись объясняет это:
sysctl -w dir.file="value"
Используя пример с file-max, мы можем изменить это значение на 16384, используя один из двух методов:
sysctl -w fs.file-max="16384"
или
echo "16384" > /proc/sys/fs/file-max
5) Максимальное количество процессов:
По умолчанию процессов 32768. Узнать текущее значение можно так:
#sysctl kernel.pid_max kernel.pid_max = 32768
Изменить это число можно так:
#sysctl kernel.pid_max=256000 kernel.pid_max = 256000
Это возможно только на 64-битных системах. Такое ограничение связано с разрядностью 32-битного числа, которое не может превышать 32768. А поскольку эти лимиты определены как тип int, то соответственно действует такое ограничение. Если же вы попробуете изменить, то получите такое сообщение:
# sysctl kernel.pid_max=327600 error: "Invalid argument" setting key "kernel.pid_max"
6) Утилита lsof:
Утилита, служит для вывода информации о том, какие файлы используются теми или иными процессами.Ниже будет продемонстрировано несколько полезных примеров работы этой утилиты.
- Список всех открытых файлов
$lsof
Показывает все открытые файлы текущего пользователя (если root — тогда все файлы) всеми процессами.
- Какие процессы используют файл file
#lsof /path/to/file
Можно указать несколько файлов через пробел, тогда получите суммарный список процессов.
- Какие процессы/файлы использует пользователь user
#lsof -u user
Если хотите узнать информацию по нескольким пользователям, разделите их имена запятой. Для групп используйте конструкцию ‘-g groupname’
- Какие процессы открыты программой prog_name
#lsof -c prog_name
Можно указывать неполное имя. [lsof] будет искать по указанному буквосочетанию. Если нужно узнать информацию для нескольких приложений, разделяйте их имена пробелом и перед каждым именем должно идти ‘-c’
- Какие файлы открыты pid’ом NNN
#lsof -p NNN
- Список всех открытых интернет сокетов
#lsof -i
Если нужно посмотреть только tcp сокеты, то после ‘i’ через пробел добавляем tcp. Аналогично и для udp.
Так же можно посмотреть и список всех unix сокетов:
#lsof -U
- Просмотр ресурсов в realtime
Можно задать период обновления информации, например, 1 секунда:
#lsof -r 1 -u username
будет обновлять информацию об использованных пользователем username процессах, каждую секунду.
- Вывод только pid’ов
По умолчанию, выводится таблица с колонками. Но если требуется вывести только сами pid’ы, можно воспользоваться такой командой:
#lsof -t -u username
7) Поиск всех pid’ов процесса:
Есть одна замечательная утилита pidof, которая позволяет найти все pid’ы связанные с определённым процессом. К примеру, найдём все pid’ы apache2:
# pidof apache2 9370 9369 9368 9367 9364 9362 9314 9280 9277 9268 4940
В большинстве дистрибутивов это обычный симлинк на /sbin/killall5:
#file /bin/pidof /bin/pidof: symbolic link to `../sbin/killall5'
Быстрое копирование данных при помощи Python
Иногда необходимо быстро предоставить доступ к файлам на машине Linux. В случае, если на такой машине имеется установленный python, то можно запустить простой HTTP-сервер, который предоставит такой доступ(на порту 8080):
$ python -m SimpleHTTPServer 8080
или таким образом:
$ python3 -m http.server 8080
Ссылки
nixadmin.ru — копирование "на лету"
Резервное копирование базы данных и файлов по SSH
Работаем с процессами