Рассел Сейдж. Приемы профессиональной работы в unix перевод "Tricks of the unix masters" by Russel G

Вид материалаДокументы

Содержание


Возможные модификации командного файла
Формат вызова
Подобный материал:
1   ...   10   11   12   13   14   15   16   17   ...   45

объясняет наличие символа "/" в конце присвоения значения переменной

DRIVE в строке 16. Полное выражение должно быть таким: B:/subdir/file.

Если операция - удаление файлов, комбинация устройство/файл удаляется

выполнением команды dosrm. Попутно заметим, что маршрутное имя есть

нечто гибкое (или небрежное, в зависимости от того, как вы смотрите на

него) в том смысле, что вы можете сказать A:/subdir или A:subdir. Оба

варианта правильны. После того как все файлы будут обработаны, времен-

ный файл удаляется.


ВОЗМОЖНЫЕ МОДИФИКАЦИИ КОМАНДНОГО ФАЙЛА


Одно из мест, где вы можете настраивать dosflp, это регулярные вы-

ражения. Уже включены выражения для .asm, .c и .h, но вы можете изме-

нить это или добавить больше ключей для любой последовательности, кото-

рую вы часто используете.


3.3. Средства получения резервных копий

3.3.1. autobkp - автоматичеески наращивамый файл резервной копии


------------------------------------------------------------------------


Имя: autobkp

_____________________________________________________________________


autobkp Автоматически наращиваемый файл резервной копии


НАЗНАЧЕНИЕ


Производит поиск по дереву файлов, которые изменялись за последние

24 часа, и пересылает их в другую систему (посредством uucp) или пере-

мещает их в другую область жесткого диска.


ФОРМАТ ВЫЗОВА


autobkp [-c] [>logfile]

-c копирует файлы в другое место диска вместо

использования uucp


Пример вызова

autobkp < filelist >> bkplog

Копирует все файлы, указанные в filelist,

и записывает имена файлов в файл с именем bkplog


Командный файл autobkp

1 :

2 # @(#) autobkp v1.0 Automatic file backup Author: Russ Sage


4 if [ $# -gt 1 ]

5 then echo "autobkp: argument error" >&2

6 echo "usage: autobkp [-c] [>logfile]" >&2

7 exit

8 fi


10 if [ "$1" = "-c" ]

11 then COPY=on

12 else COPY=off

13 fi


15 echo "\nBACKUP DATE `date '+%a %m/%d/%y %H:%M:%S'`"

16 echo "-----------------------------------------"


18 SYSTEM='' # destination system uucp node name

19 : ${SYSTEM:=`uuname -l`}


21 echo "Sourse system:\t\t`uuname -l`\nDestination system:\t$SYSTEM"


23 while read SRCDIR DESTDIR FILES

24 do

25 if [ ! -d $SRCDIR ]

26 then echo "autobkp: $SRCDIR is not a directory"

27 continue

28 fi


30 cd $SRCDIR

31 echo "\nFinding files in: $SRCDIR"


33 for FILE in `find . -type f -ctime 0 -name "$FILES" -print`

34 do

35 case $COPY in

36 off) uucp $FILE $SYSTEM!$DESTDIR;;

37 on) cp $FILE $DESTDIR;;

38 esac

39 echo " Transferred $FILE to $DESTDIR"

40 done

41 done


Переменные среды выполнения


COPY Флаг, определяющий, используется команда uucp или cp

FILE Имя каждого файла, найденного в исходном списке маршрутов

FILES Символ-шаблон, указывающий, какие файлы определены

PATH1 Имя маршрута-источника

PATH2 Имя маршрута-приемника

SYSTEM Имя системы-приемника для uucp


Описание

Зачем нам нужен autobkp?


Как мы заметили, файлы в UNIX плодятся как кролики. Чем больше

файлов мы создаем, тем сильнее желание сохранять их упорядоченными. До-

вольно легко стать ленивым или получить ложное представление о безо-

пасности и пренебречь регулярным копированием.

Вы можете подходить к копированию файлов несколькими путями. Наи-

более популярной стратегией является выполнение наращиваемого копирова-

ния, когда вся система копируется с некоторой начальной даты (и иногда

повторно с регулярными интервалами, но не часто). При коротких интерва-

лах (обычно ежедневно) файловая система проверяется на наличие файлов,

которые были модифицированы или добавлены за последние 24 часа. Такие

файлы копируются, поэтому копия в целом поддерживается такой, какой яв-

ляется система в настоящее время.

Где размещать копируемые файлы - это еще один интересный вопрос,

зависящий от конфигурации вашей системы, количества доступного прост-

ранства и важности данных. Давайте рассмотрим некоторые возможности.

Автономная микро- или супермикросистема может иметь всего один

жесткий диск. Если диск содержит достаточно места для размещения друго-

го раздела, вы можете копировать в этот раздел. Раздел может также

использоваться как неструктурированное устройство в отличие от файловой

системы и рассматриваться как магнитная лента или гибкий диск. Среди

других возможностей хранения информации могут быть второй жесткий диск,

кассетная лента или устройство копирования на ленту. Если вам недоступ-

на ни одна из этих возможностей, вы всегда можете копировать на гибкие

диски. Это утомительная ручная работа, но она может быть выполнена при

помощи команд tar или cpio.

Если вы также имеете доступ к другой, большей системе, такой как

общий главный компьютер, вы можете копировать файлы, посылая их в эту

систему посредством команды uucp. Даже если вы имеете достаточно места

в вашей собственной системе для сохранения ваших копий, у вас может

быть очень сильное желание послать копии всех важных файлов в главную

машину, потому что это даст вам выносную копию за пределами вашего

места расположения. Пожары, наводнения и др

ются.

Нам необходим механизм, который обычно запускается автоматически

(по команде cron или с помощью процедуры at, описанной в главе 5). Сна-

чала он обнаруживает все файлы, которые были изменены в последние 24

часа (надеемся, что вы уже имеете первоначальную копию всего). Он начи-

нает искать файлы из указанных каталогов и копировать подходящие файлы

в указанные каталоги-приемники. Он копирует файлы, используя утилиты,

которые наилучшим образом соответствуют используемой вами конфигурации.

Все эти вещи выполняются нашим командным файлом autobkp.


Что делает autobkp?


Вы перечисляете маршруты и autobkp находит файлы по этим маршрутам

и копирует их в то место, которое вы указали. Вы можете указывать имена

файлов по образцам, таким как *.c, *.h или каким-либо еще. С помощью

autobkp вы можете копировать важные файлы без копирования всех файлов.

Иногда это удобно - пропускать файлы при копировании. Типичные файлы,

которые вы, возможно, не хотите копировать, - это очень большие файлы

(не являющиеся важными, как файл core и файлы данных), временные файлы

(как *.o, которые вновь создаются при каждой новой компиляции) и испол-

няемые файлы, если у вас есть исходные программы на языке Си и вы може-

те их скомпилировать для получения новых исполняемых файлов. Пропуская

эти файлы, вы можете уменьшить размер ваших копий на мегабайты.

По умолчанию копирование производится командой uucp, которая пред-

полагает, что у вас подчиненная система по отношению к главной машине и

копирует ваши файлы в большую систему. Если вы хотите копировать ваши

файлы в другое место жесткого диска или на другой жесткий диск, исполь-

зуйте ключ -c для копирования командой cp вместо использования команды

uucp.

Во время процесса копирования на стандартный вывод выводятся сооб-

щения о состоянии дел. Это позволяет легко собрать все сообщения путем

переадресации stdout на время копирования. Если вы выполняете autobkp

вручную, сообщения выводятся на экран. Первое сообщение - это заголо-

вок, который печатает день, дату и время. Это выглядит так:


--------------------------

| BACKUP DATE Fri 05/23/86 17:33:35

|


Второе сообщение определяет систему-источник и систему-приемник.

Оно появляется ниже. В нашем примере система-источник - russ, а систе-

ма-приемник - vax.


--------------------------

| Source system: russ

| Destination system: vax


При каждом входе в систему-источник выдается следующее сообщение:


-----------------------------

| Finding files in: src_dir

|


где выражение src_dir - это место, откуда файлы будут переданы в

цикл копирования. Обратите внимание, что первое имя должно быть именем

каталога, потому что autobkp начинает именно с этого места поиск фай-

лов. Если первое имя не является каталогом, программа печатает сообще-

ние об ошибке и продолжает работу со следующим набором источник/прием-

ник для копирования.


Для каждого найденного файла печатается следующее сообщение после

завершения копирования:


------------------------------

| Transferred file to dest_dir

|

которое указывает, что файл file был скопирован в каталог-приемник

с именем dest_dir.


Файл со списком маршрутов


Чтобы сделать интерфейс настолько гибким, насколько это возможно,

autobkp читает стандартный ввод. Переназначая stdin, вы можете поддер-

живать разные списки файлов, которые необходимо копировать и переклю-

чать их в командной строке. Вы можете иметь один список маршрутов для

системных файлов, другой для исходных файлов, третий для личных файлов,

четвертый для файлов с готовым продуктом и так далее. Для каждой из

этих групп файлов создается список маршрутов и передается в качестве

входа для autobkp. Входные данные читаются как три поля: FROM, TO и

TYPE. Поле FROM - это каталог-источник. Поиск файлов начинается с этого

места. Напомним, что autobkp проходит вниз до конца дерева файлов, на-

чиная с указанного каталога.

Поле TO - это каталог-приемник, куда все файлы, найденные для дан-

ной записи в файле со списком маршрутов, помещаются на машине-приемнике

или в разделе-приемнике.

Поле TYPE - это описатель-шаблон, который сообщает autobkp, какие

файлы искать. Его значение может быть *, *.c, *src*, и так далее. Как

мы увидим позже, этот описатель передается команде find Unix, которая

фактически и выполняет поиск файлов. Вы можете использовать любое выра-

жение в поле TYPE, если оно соответствует синтаксису find.

Итак: все файлы, которые были изменены в последние 24 часа, обна-

руживаются в списке FROM с помощью описателя TYPE и копируются в об-

ласть TO.

Ниже приводится типичный файл со списком маршрутов. Он указывает

несколько каталогов, в которых производится поиск файлов. Обратите вни-

мание, что эти каталоги находятся под регистрационным каталогом: если

вы хотите скопировать ВЕСЬ регистрационный каталог полностью, вы можете

указать этот каталог, но здесь мы хотим выбрать только указанные ката-

логи.

/usr/russ/bin /pack1/russ/.bkp/bin *

/usr/russ/doc /pack1/russ/.bkp/doc *

/usr/russ/src /pack1/russ/.bkp/src *.c

/usr/product1 /pack1/russ/.bkp/product1 *.[ch]


Эти строки копируют каталоги bin, doc и src на локальной машине

автора. В случае каталога src мы указали, что копировать нужно только

исходные файлы на языке Си. Будет также скопирована некоторая полезная

информация из другого места этой же системы. Будут скопированы только

файлы с расширением *.c и *.h.

Место назначения (прямо указанное в командном файле автоматическо-

го копирования) - другая система UNIX. Место назначения - некоторый

смонтированный диск, регистрационный каталог, подкаталог копий (bkp).


Использование cron


Теперь, когда процедура autobkp знает, что искать, давайте скажем

ей, когда искать. Cron, вечный резидентный хранитель времени, может

легко выполнить эту работу. Входные данные для cron обычно устанавлива-

ются системным администратором (или кем-либо, кто имеет права записи в

/usr/lib/crontab), так что вы должны попросить администратора устано-

вить для вас вход в файл данных cron. Для получения дополнительной ин-

формации о входных данных cron, прочтите cron(1M) в Руководстве адми-

нистратора. Коротко говоря, полями в файле /usr/lib/crontab являются

минута, час, день месяца, месяц и день недели. Используя *, мы можем

установить принудительно многие из этих полей во все возможные значе-

ния. Входные данные для cron, копирующие мой регистрационный каталог в

4.00 утра каждый день каждой недели каждого месяца года, выглядят так:


0 4 * * * /usr/russ/bin/autobkp.cron


Обратите внимание, что вход в cron вызывает управляющую процедуру

вместо того, чтобы непосредственно использовать autobkp. Имеется

несколько важных причин, чтобы написать процедуру на базе утилиты

autobkp. Во-первых, cron не печатает диагностическую информацию на ваш

терминал, поэтому если что-нибудь идет не так, вы никогда об этом не

узнаете. Во-вторых, проще поддерживать усеченную версию autobkp, а зву-

ковые предупреждения добавлять в управляющую процедуру. Вы можете сде-

лать собственные модификации управляющей программы и не беспокоиться об

отсутствии сообщений от самой утилиты. Управляющую программу можно

настолько усложнить, насколько вы желаете. Представленная здесь вполне

работоспособна, но легко может быть дополнена.


# Cron-driven autobkp driver

echo "backed up: `date`" > /dev/tty00

/usr/bin/autobkp < /usr/russ/bin/autobkpath

>> /usr/russ/bin/autobkp.log


Этот драйвер выдает сообщение на терминал, запускает autobkp,

использует для ввода файл со списком маршрутов в каталоге bin и помеща-

ет все выводные сообщения в файл протокола. Отметим, что имя терминала

дано как абсолютное (tty00). Это правильно только в том случае, когда в

вашей системе имеется такой терминал. Использование этого имени терми-

нала позволяет сообщению появиться на экране даже если никто на нем не

зарегистрирован. Это хорошо, потому что первое, что вы сможете увидеть

утром на вашем экране - это сообщение. Если у вас нет указанного терми-

нала, вы можете сделать что-то другое, например, передачу самому себе

почтового сообщения.

Примеры

1. $ autobkp

Запускает программу без передачи ей файла со списком маршрутов и

без файла протокола. Поскольку поля FROM, TO, TYPE ищутся в стандартном

вводе, введите их вручную. Когда вы нажмете возврат каретки, autobkp

выполнит указанные действия, напечатает информацию на экран терминала и

будет ожидать дальнейшего ввода. Для завершения выполнения командного

файла введите d (в результате оператор read вернется с ненулевым ста-

тусом).

2. $ autobkp < pathlist

Получает все входные данные из файла со списком маршрутов, но пе-

чатает всю протокольную информацию на экран терминала. Autobkp заверша-

ется, когда прочитает все данные в файле pathlist.

3. $ autobkp >> logfile

Как и в первом случае, списки маршрутов должны быть введены с кла-

виатуры. Все выходные данные выводятся в файл протокола, а не на экран.

Для завершения autobkp введите d.

4. $ autobkp -c < pathlist >> logfile

Копирует файлы из одной области жесткого диска в другую (опреде-

ленную каталогом-приемником в файле pathlist). Берет все входные данные

из файла pathlist и выводит все выходные данные в файл logfile.


Пояснения


Строки 4-8 выполняют проверку на наличие ошибок. Autobkp может

быть вызван либо без указания опций, либо с одной опцией (-c, при

использовании cp). Вспомните, что переназначение ввода-вывода НЕ прини-

мается во внимание при рассмотрении аргументов, потому что командный

процессор интерпретирует символы переназначения и то, что следует за

ними, до вызова команды. Таким образом, если количество позиционных па-

раметров больше одного (#1 -gt 1), получаем ошибочное условие. Затем

выдается сообщение об ошибке и синтаксическая подсказка и программа за-

вершается.

В строках 10-13 проверяется использование ключа -c. Обратите вни-

мание, что мы не проверяем, равен ли параметр $# единице и не пытаемся

выделить первый символ, чтобы посмотреть, равен ли он "-". Это потому,

что такая проверка приведет к ошибке, если не указан никакой ключ (что

является верным синтаксисом, как указывалось ранее).

Если мы сказали

if [ $1 = -c ]

и не указали ключей, то команда проверки не сработает и будет вы-

дано сообщение о том, что "no argument in the statement" ("в операторе

нет аргументов"). Но если мы выполним экранирование, например, так:

if [ "$1" = "-c" ]

то кавычки допускают нулевое значение аргумента, так что проверка

правильно оценит недостающее значение $1 как "равен ли нуль -c?" Это

даст результат "ложь", поэтому все хорошо.

Попутно давайте внимательно рассмотрим работу команды проверки. Вы

можете выполнить проверку значения двумя способами. Первый - сравнение

строк, а второй - числовое сравнение. Переменные командного процессора

ВСЕГДА хранятся в виде строк. Вы можете, тем не менее, заставить систе-

му рассматривать эти последовательности как числа и интерпретировать их

значения как числовые, подобно оператору number = val(STRING$) языка

Бейсик. Вы можете сказать системе, чтобы она изменила свой способ

рассмотрения символьных строк путем изменения синтаксиса операции срав-

нения. Для символьных строк сравнение выглядит так:

str1 = str2

а числовое сравнение выглядит так:

num1 -eq num2

-lt

-gt

Сверьте это с руководством. Если вы попытаетесь смешать символьное

сравнение с числовым, сравнение не будет работать. У меня забрало много

месяцев программирование на командном процессоре, пока наконец я заме-

тил это незначительное различие. Если не рассматривать подробно что-ли-

бо подобное, то такие технические ошибки кажутся неуловимыми, но можно

найти объяснения, почему что-нибудь работает не так.

Вернемся к возможности проверки кода. Если был передан ключ -c,

переменная COPY устанавливается, что значит "Да, мы собираемся копиро-

вать командой cp, а не использовать uucp". Если ключ -c не использу-

ется, переменная COPY не устанавливается.

В строках 15-16 печатается заголовочное сообщение о том, что будет

выполняться копирование. Обратите внимание, что мы спрятали команду

date системы UNIX внутри оператора echo, сократив число перехваченных

данных, которые мы должны иметь, чтобы получить дату непосредственно.

Проследите за кавычками в этом операторе. Внешние кавычки являются

двойными для того, чтобы упаковать весь аргумент для оператора echo.

Знаки ударения (`) обрамляют команду date так, что она является "выпол-

няемой внутри" и ее выходное сообщение перехватывается для наших нужд.

Одинарные кавычки внутри команды date используются для передачи форма-

та, который изменяет внешний вид значений так, чтобы заголовок выглядел

более красиво. В конце оператора echo кавычки следуют одна за другой.

Это не представляет проблемы, поскольку во вложенности нет никакой

двусмысленности. Вы должны помнить, что нужно следить за ситуацией,

когда вы и командный процессор можете расходиться во мнениях, т. е.,

когда вы должны обращаться к записи вида "\".

В строке 18 переменной SYSTEM присваивается имя удаленной системы,

в которую вы будете копировать командой uucp. Здесь она равна нулю, что

позже вызовет выполнение другой операции для обеспечения функционирова-

ния по умолчанию. Если же вы хотите всегда копировать на вполне опреде-

ленную систему, модифицируйте эту строку, чтобы назначить имя этой

системы. Если оставить строку 18 так, чтобы она назначала ноль, строка

14 поймает это значение и присвоит переменной SYSTEM имя вашей текущей