Дейв Тейлор - Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание
- Название:Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание
- Автор:
- Жанр:
- Издательство:Питер
- Год:2017
- Город:СПб.
- ISBN:978-5-496-03029-8
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Дейв Тейлор - Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание краткое содержание
Цель этой книги — продемонстрировать практические приемы программирования сценариев на bash и познакомить с самыми распространенными утилитами на коротких и компактных примерах, не вдаваясь в излишние подробности. Экспериментируйте с этими сценариями — ломайте, исправляйте и приспосабливайте их под свои нужды, чтобы понять, как они работают. Только так вы сможете решать самые сложные задачи.
Сценарии командной оболочки. Linux, OS X и Unix. 2-е издание - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Если говорить более конкретно, первый блок использует мощную функцию getopts для анализа всех поддерживаемых флагов (-l, −u, — r) в цикле while. Это наиболее типичный способ использования getopts, который снова и снова будет встречаться в книге. Обратите внимание на команду shift $(($OPTIND — 1)) в строке
: переменная OPTIND устанавливается функцией getopts, благодаря чему сценарий получает возможность сдвинуть входные параметры вниз (то есть значение параметра $2 сместится в параметр $1, например), вытолкнув тем самым обработанные параметры, начинающиеся с дефиса.
Поскольку этот сценарий использует системную утилиту lockfile, он сначала проверяет ее доступность в списке путей пользователя и завершается с сообщением об ошибке, если утилита недоступна. Далее следует простая условная инструкция
, выясняющая, какая операция запрошена — блокировка или разблокировка, — и производится соответствующий вызов утилиты lockfile.
Запуск сценария
Сценарий filelock относится к категории сценариев, которые редко используются сами по себе, и для его проверки потребуется открыть два окна терминала. Чтобы установить блокировку, просто укажите имя файла, который будет играть роль блокировки, в аргументе сценария filelock. Чтобы снять блокировку, запустите сценарий еще раз с флагом −u.
Результаты
Сначала создадим заблокированный файл, как показано в листинге 1.23.
Листинг 1.23.Создание файла-блокировки командой filelock
$ filelock /tmp/exclusive.lck
$ ls −l /tmp/exclusive.lck
-r-r-r-··1 taylor··wheel··1 Mar 21 15:35 /tmp/exclusive.lck
Когда в следующий раз вы попытаетесь установить ту же блокировку, filelock выполнит указанное количество попыток (10 по умолчанию) и завершится с ошибкой (как показано в листинге 1.24):
Листинг 1.24.Ошибка при попытке создать файл-блокировку обращением к сценарию filelock
$ filelock /tmp/exclusive.lck
filelock: Failed: Couldn’t create lockfile in time.
Завершив работу с файлом, можно освободить блокировку, как показано в листинге 1.25.
Листинг 1.25.Освобождение блокировки с помощью сценария filelock
$ filelock −u /tmp/exclusive.lck
Чтобы увидеть, как сценарий действует в двух терминалах, выполните команду разблокировки в одном из них, пока в другом сценарий крутится в цикле, пытаясь приобрести блокировку.
Усовершенствование сценария
Поскольку наличие блокировки определяется сценарием, было бы полезно добавить еще один параметр, ограничивающий время ее действия. Если команда lockfile завершится неудачей, можно проверить последнее время доступа к файлу-блокировке и, если он старше значения этого параметра, безопасно удалить его, добавив, при желании, вывод предупреждающего сообщения.
Скорее всего, это не затронет вас, но lockfile не поддерживает работу с сетевой файловой системой (NFS) на смонтированных сетевых устройствах. Действительно надежный механизм блокировки файлов в NFS чрезвычайно сложен в реализации. Лучшее решение этой проблемы — всегда создавать файлы-блокировки только на локальных дисках или задействовать специализированный сценарий, способный управлять блокировками, используемыми несколькими системами.
№ 11. ANSI-последовательности управления цветом
Вероятно, вы замечали, что разные приложения командной строки поддерживают разные стили отображения текста. Существует большое количество вариантов оформления. Например, сценарий может выводить определенные слова жирным шрифтом или красным цветом на желтом фоне. Однако работать с ANSI -последовательностями (American National Standards Institute — американский национальный институт стандартов) очень неудобно из-за их сложности. Чтобы упростить их применение, в листинге 1.26 создается набор переменных, значениями которых являются ANSI-последовательности, управляющие цветом и форматированием.
Код
Листинг 1.26.Функция initializeANSI
#!/bin/bash
# ANSI-последовательности управления цветом — используйте эти переменные
#·· для управления цветом и форматом выводимого текста.
#·· Имена переменных, оканчивающиеся символом 'f’, соответствуют цветам шрифта
#·· (foreground), а имена переменных, оканчивающиеся символом 'b’, соответствуют
#·· цветам фона (background).
initializeANSI()
{
··esc="\033" # Если эта последовательность не будет работать,
············ #·· введите символ ESC непосредственно.
··# Цвета шрифта
··blackf="${esc}[30m";··redf="${esc}[31m";·· greenf="${esc}[32m"
··yellowf="${esc}[33m"··bluef="${esc}[34m";··purplef="${esc}[35m"
··cyanf="${esc}[36m";·· whitef="${esc}[37m"
··# Цвета фона
··blackb="${esc}[40m";··redb="${esc}[41m";·· greenb="${esc}[42m"
··yellowb="${esc}[43m"··blueb="${esc}[44m";··purpleb="${esc}[45m"
··cyanb="${esc}[46m";·· whiteb="${esc}[47m"
··# Жирный, наклонный, с подчеркиванием и инверсное отображение
··boldon="${esc}[1m";···· boldoff="${esc}[22m"
··italicson="${esc}[3m";··italicsoff="${esc}[23m"
··ulon="${esc}[4m";······ uloff="${esc}[24m"
··invon="${esc}[7m";······invoff="${esc}[27m"
··reset="${esc}[0m"
}
Как это работает
Если вы привыкли использовать язык разметки HTML, работа с этими последовательностями может показаться вам слишком сложной. В HTML вы просто вставляете открывающие теги и закрываете их в обратном порядке, следя за тем, чтобы закрыть все открытые теги. Чтобы выделить наклонным шрифтом фрагмент приложения, отображаемого жирным шрифтом, можно написать такой код HTML:
this is in bold and this is italics within the bold
Попытка закрыть тег, управляющий жирностью шрифта, раньше, чем тег, управляющий наклонным отображением, может вызвать беспорядок в отдельных веб-браузерах. Но в случае с ANSI-последовательностями дело обстоит иначе: некоторые из них фактически отменяют действие предыдущих, а также существует общая последовательность сброса, отменяющая действие всех других. Ее обязательно нужно добавить в конце вывода, а за последовательностью, включающей тот или иной режим форматирования, должна идти соответствующая ей последовательность, выключающая этот режим. Использовав переменные из сценария, предыдущее предложение можно вывести, как показано ниже:
${boldon}this is in bold and ${italicson}this is
italics${italicsoff}within the bold${reset}
Запуск сценария
Чтобы опробовать этот сценарий, нужно сначала вызвать функцию инициализации, а затем выполнить несколько команд echo с разными комбинациями цвета и эффектами форматирования:
initializeANSI
echo −e "${yellowf}This is a phrase in yellow${redb} and red${reset}"
Интервал:
Закладка: