Linux и UNIX: программирование в shell. Руководство разработчика
Linux и UNIX: программирование в shell. Руководство разработчика читать книгу онлайн
Данная книга является практическим руководством по программированию интерпретатора Bourne shell -cтандартного командного интерпретатора в UNIX, полностью совместимого с интерпретатором BASH shell в Linux. Книга предназначена для начинающих и опытных программистов и содержит множество полезных примеров, советов и подсказок. С ее помощью читатель сможет быстро научиться создавать shell–сценарии для реальных задач и ситуаций, возникающих в большинстве систем UNIX и Linux.
Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних чтение данного контента СТРОГО ЗАПРЕЩЕНО! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту [email protected] для удаления материала
Обратите внимание на применение двойных кавычек, которые позволяют в потоке данных вывода указывать пробелы.
Для использования даты в качестве части имени файла проще всего воспользоваться подстановкой. Введите переменную, значением которой является заново отформатированная дата, и присоедините эту переменную к имени файла. Этим именем и будет назван журнальный файл.
В следующем примере создаются два журнальных файла. Для одного файла дата указывается в формате дд, мм, гг, а для другого — в формате дд, чч, мм.
Сценарий имеет вид:
$ pg log
#!/bin/sh
# регистрация
#
MYDATE=`date +%d%m%y`
#присоединение MYDATE к переменной LOGFILE, которая содержит действительное #имя файла регистрации.
LOGFILE=/logs/backup_log.$MYDATE
#создание файла
>$LOGFILE
MVTTIME= `date +%d%R` LOGFILE2=/logs/admin_log.$MYTIME
# создание файла
>$LOGFILE2
При выполнении этого сценария создаются два журнальных файла.
backup_log.09069 9 admin_log.09l6:18
26.1.2. Создание уникальных временных файлов
При рассмотрении специальных переменных уже обсуждалась переменная $$ Она содержит ID или номер процесса, выполняющегося в текущий момент. Эти сведения применяются при создании временных файлов в текущем сценарии, поскольку ID процесса уникален в рамках сценария. Достаточно лишь создать файл и присоединить к нему символ $$, После завершения можно удалить все файлы, имеющие символ $$ в качестве расширения. Интерпретатор shell оценивает переменную $$ как текущий ID процесса и удаляет эти файлы, но оставляет файлы, к которым присоединен ID процесса.
В командной строке введите следующую команду:
$ echo $$
281
Это значение ID процесса приведено для примера; в вашем случае, скорее всего, будет получено другое значение. Если создать новый сеанс и ввести эту же команду, получится другой номер, поскольку будет запущен иной процесс.
$ echo $$
382
Ниже приводится сценарий, который создает два временных файла, обрабатывает и затем удаляет их.
$ pg tempfiles
#!/bin/sh
#tempfiles
#именование временных файлов
HOLD1=/tmp/hold1.$$
HOLD2=/tmp/hold2.$$
#выполнение определенной обработки с помощью этих файлов
df -tk > $HOLD1
cat $HOLD1 > $HOLD2
# удаление файлов
rm /tmp/*.$$
При выполнении этого сценария создаются следующие два файла.
hold1.408 hold2.408
Когда указывается команда rm /tmp/*.$$, интерпретатор shell в действительности выполняет команду rm /tmp/*.408.
Важно помнить, что ID процесса является уникальным только в конкретный момент времени. Например, если приведенный выше сценарий выполнить снова, получим новый ID процесса, поскольку речь идет о другом процессе.
Благодаря использованию даты можно отслеживать файлы, созданные для специальных целей. Помимо этого, значительно облегчается очистка файлов на базе определенных дат, поскольку с первого взгляда видно, какие файлы создавались раньше, а какие позже.
Временные файлы создаются легко и быстро; кроме того, они являются уникальными для данного процесса. После того как сценарий завершает обработку, их несложно удалить без искажения остальной информации.
26.2. Сигналы
Сигнал относится к типу сообщений, которые пересылаются из системы для информирования команды или сценария о совершении какого‑либо события. Обычно речь идет об ошибках, связанных с функционированием памяти, о проблемах с доступом к информации или об определенных пользовательских попытках прекратить процесс. Сигналы представлены числами. Ниже приводится список наиболее распространенных сигналов и их значений.
Номер сигнала
Название сигнала
Значение
1
SIGHUP
"Зависание" или прекращение выполнения родительского процесса
2
SIG1NT
Прерывание с помощью клавиатуры; обычно используется комбинация клавиш [Ctrl+C]
3
SIGQUIT
Завершение выполнения с помощью клавиатуры
9
SIGKILL
Прекращение выполнения определенного процесса
11
SIGSEGV
Нарушение сегментации (память(
15
SIGTERM
Завершение выполнения программы (завершение выполнения программы, заданное по умолчанию)
Существует сигнал 0, который ранее уже рассматривался (при создании файла .logout). Этот сигнал является сигналом "выхода из интерпретатора shell". Чтобы переслать сигнал 0, введите в командную строку команду exit либо примените к процессу или укажите в командной строке комбинацию клавиш [Ctrl+D].
Для пересылки сигнала используется формат:
kill [- номер сигнала:| имя сигнала] ID процесса
Если команда kill вводится без указания номера или названия сигнала, то она по умолчанию относится к сигналу с номером 15. Для просмотра списка всех сигналов примените следующую команду:
$ kill -1
1)
SIGHUP
2)
SIGINT
3)
SIGQUIT
4)
SIGILL
5)
SIGTRAP
6)
SIGIOT
7}
SIGBUS
8)
SIGFPE
9)
SIGKILL
10)
SIGUSR1
11)
SIGSEGV
12)
SIGUSR2
13)
SIGPIPE
14)
SIGALRM
15)
SIGTERM
17)
SIGCHLD
18)
SIGCONT
19)
SIGSTOP
20)
SIGTSTP
21)
SIGTTIN
22)
SIGTTOU
23)
SIGURG
24)
SIGXCPU
25)
SIGXFSZ
26)
SIGVTALRM
27)
SIGPROF
28)
SIGWINCH
29)
SIGIO
30)
SIGPWR
26.2.1. Уничтожение процесса
При пересылке сигнала 1 процесс заново считывает файл конфигурации. Например, если при выполнении процесса под названием демон dns файлы базы данных изменяются, не следует уничтожать демон и заново запускать его. Выполните всего лишь команду kill -1. В этом случае файлы конфигурации просматриваются заново.
Ниже приводится пример пересылки сигнала 9 (гарантированное уничтожение) для уничтожения процесса mon_web, который выполняется в системе. Сначала примените команду ps для создания процесса.
$ ps -ef | grep mon_web | grep -v root
157 ? S 0:00 mon_web
Если в системе не поддерживается команда ps -ef, то воспользуйтесь командой ps xa. Для уничтожения процесса можно применить команду:
kill -9 157
или
kill -s SIGKILL 157
В некоторых системах можно не указывать опцию -s. Например, введите команду
kill SIGKILL 157
В приведенном ниже сценарии уничтожение процесса основано на использовании имени процесса. Имя устраняемого процесса указывается в виде параметра. Выполняется проверка, что данный процесс был действительно уничтожен. Утилита grep используется для обнаружения всех совпадающих имен процесса. Если соответствующие имена обнаруживаются, поступает запрос пользователю, следует ли уничтожить найденные процессы. Для уничтожения процесса применяется команда kill -9.
Соответствующий сценарий выглядит следующим образом:
$ pg pskill
#!/bin/sh
# pskill