testfeatures.sh (4KB)················ topcheck (3 entries)
tweakmktargs.c (4KB)··················websites.tar.gz (18.85MB)
Усовершенствование сценария
С данным сценарием может возникнуть проблема, если в системе имеется пользователь, обожающий последовательности из трех «крышек» в именах файлов. Конечно, это весьма маловероятно — из 116 696 файлов в нашей тестовой системе Linux не нашлось ни одного, имя которого содержало хотя бы один символ крышки, — но если такое случится, вывод сценария окажется испорченным. Если вас волнует эта проблема, попробуйте преобразовывать пробелы в другую последовательность символов, еще менее вероятную в именах файлов. Четыре «крышки»? Пять?
№ 19. Поиск файлов по именам
В системах Linux имеется очень практичная команда locate, которая не всегда присутствует в других разновидностях Unix. Эта команда выполняет поиск в предварительно созданной базе данных имен файлов по регулярному выражению, указанному пользователем. Нужно быстро найти мастер-файл
$ locate.cshrc
/.Trashes/501/Previous Systems/private/etc/csh.cshrc
/OS9 Snapshot/Staging Archive/:home/taylor/.cshrc
/private/etc/csh.cshrc
/Users/taylor/.cshrc
/Volumes/110GB/WEBSITES/staging.intuitive.com/home/mdella/.cshrc
Как видите, в системе OS X мастер-файл
Код
Описываемый метод поиска файлов прост в реализации и предполагает создание двух сценариев. Первый (в листинге 2.14) создает базу данных всех имен файлов, вызывая команду find, а второй (в листинге 2.15) — просто вызывает команду grep для поиска в новой базе данных.
Листинг 2.14. Сценарий mklocatedb
··#!/bin/bash
··# mklocatedb — создает базу данных для locate с использованием find.
··#·· Для запуска этого сценария пользователь должен обладать привилегиями
··#·· суперпользователя root.
··locatedb="/var/locate.db"
····echo "Must be root to run this command." >&2
····exit 1
··fi
··find / −print > $locatedb
··exit 0
Второй сценарий еще короче.
Листинг 2.15. Сценарий locate
#!/bin/sh
# locate — выполняет поиск в базе данных по заданному шаблону
locatedb="/var/locate.db"
exec grep −i "$@" $locatedb
Как это работает
Сценарий mklocatedb должен запускаться с привилегиями суперпользователя root, чтобы он смог увидеть все файлы во всей системе, поэтому в строке
Не удивляйтесь, если сценарию mklocatedb потребуется несколько минут или больше; он выполняет обход всей файловой системы, что требует значительного времени, даже для систем среднего размера. Результат также может получиться весьма впечатляющим. В одной из наших тестовых систем OS X файл
После создания базы данных сам сценарий locate выглядит очень простым; он просто вызывает команду grep со всеми аргументами, полученными от пользователя.
Запуск сценария
Прежде чем воспользоваться сценарием locate, необходимо запустить mklocatedb. Когда он завершит работу, вызов locate почти мгновенно будет находить совпадения в файловой системе с любыми заданными шаблонами.
Результаты