Как это часто бывает с хорошо написанными сценариями командной оболочки, половину листинга 1.22 занимает анализ входных данных и проверка на наличие ошибок. Затем выполняется инструкция if и осуществляется фактическая попытка использовать системную команду lockfile. Она вызывается с заданным числом попыток и генерирует собственное сообщение об ошибке, если ей так и не удалось заблокировать файл. А что произойдет, если предложить сценарию снять блокировку (например, удалить файл-блокировку), которой в действительности нет? В результате будет сгенерировано другое сообщение об ошибке. В противном случае 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-последовательности управления цветом
Вероятно, вы замечали, что разные приложения командной строки поддерживают разные стили отображения текста. Существует большое количество вариантов оформления. Например, сценарий может выводить определенные слова жирным шрифтом или красным цветом на желтом фоне. Однако работать с
Код
Листинг 1.26. Функция initializeANSI
#!/bin/bash
# ANSI-последовательности управления цветом — используйте эти переменные