Александр Мисюрин
12.06.2019
3591

Мониторинг изменений конфигурационных файлов fswatch

В данной статье рассмотрим возможность мониторинга изменений в конфигурационных файлах. Использовать для этого будем утилиту fstab. Данный функционал может потребоваться, если одну АТС обслуживает несколько человек или компаний, это позволит избежать путаницы, если кто либо вносит правки в файлы. Для установки утилиты последней версии (на момент написания это – 1.14.0) необходим GCC 4.9 + версии. […]

В данной статье рассмотрим возможность мониторинга изменений в конфигурационных файлах. Использовать для этого будем утилиту fstab. Данный функционал может потребоваться, если одну АТС обслуживает несколько человек или компаний, это позволит избежать путаницы, если кто либо вносит правки в файлы.

Для установки утилиты последней версии (на момент написания это – 1.14.0) необходим GCC 4.9 + версии.

На CentOs 7 его можно установить из репозиториев, однако в данной статье я использовал CentOs 6, поэтому его необходимо установить вручную.
Yum install libmpc-devel mpfr-devel gmp-devel
cd /usr/src/
curl ftp://ftp.mirrorservice.org/sites/sourceware.org/pub/gcc/releases/gcc-4.9.3/gcc-4.9.3.tar.bz2 -O
tar xvfj gcc-4.9.3.tar.bz2
cd gcc-4.9.3
./configure --disable-multilib --enable-languages=c,c++
make -j `grep processor /proc/cpuinfo | wc –l`
make install

После установки GCC устанавливаем сам fswatch:

wget https://github.com/emcrisostomo/fswatch/releases/download/1.14.0/fswatch-1.14.0.tar.gz
tar –xvzf fswatch-1.14.0.tar.gz 
cd fswatch-1.14.0
./configure
make
sudo make install 

Утилита fswatch позволяет отслеживать доступ и изменение файлов или директорий в реальном времени. Также позволяет выполнять команды консоли при появлении каких либо событий. Ниже рассмотрим вариант запуска мониторинга файла /etc/asterisk/extensions_custom.conf с выводом изменений в файл. Выводить будем события обновления файла:

fswatch –l 1 –t –x –event Updated /etc/asterisk/extensions_custom.conf >> /tmp/log_fs.log
Вывод в консоль и в файл

Данную команду можно запустить в screen, а затем проверять содержимое файла, однако сейчас не пишется IP адрес и пользователь, которые проводили изменения. Чтобы отследить этот момент можно использовать команду last и по времени найти необходимого пользователя.

Вывод команды last

Полученные записи в файле можно как просматривать через утилиты командной строки, так и использовать в дальнейшем построении статистики изменений файлов. Рассмотрим это позже. Более подробно параметры утилиты, можно посмотреть с помощью fswatch –h, или man fswatch.

Inotifywatch

Следующая утилита мониторинга – Inotifywatch, обладает немного более расширенным функционалом. Для начала установим необходимые пакеты.

Yum install inotify-tools

Данная утилита также собирает статистику доступа к файловой системе с помощью монитора inotify. По окончанию работы – выводит информацию об общем количестве событий и количестве событий каждого типа и фалы, для которых произошли эти события.

Сбор статистики по файлу за 300 секунд
Данная утилита не выводит информацию в реальном времени, только по завершению, либо с помощью CTRL+C, либо по таймауту через параметр –t

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

Inotifywait

В отличие от предыдущей, ждет возникновения события и сразу же выводит его на экран. Эту утилиту можно использовать аналогично fswatch, тоесть записывать события в файл в реальном времени, но в отличие от fswatch, в этой утилите есть параметр для записи событий в файл.

Вывод в файл

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

-format – определяет формат вывода событий, в данном примере будет выглядеть так: «%T — %w — %e»

-timefmt (работает только при использовании format %T) – указываем формат вывода даты, по аналогии с обычным выводом даты bash: «%Y-%m-%d %H:%I:%s»

И организуем вывод этой информации в файл:

inotifywait -m /etc/asterisk/extensions_custom.conf --format "%T - %w - %e"  --timefmt "%Y-%m-%d %H:%I:%s" >> /tmp/log_in.log
Вывод в файл

Аналогично можем организовать для других файлов. В дальнейшем будет рассмотрено расширение функционала мониторинга, на основе этих утилит.

Подписаться
Уведомить о
guest
0 комментариев
Старые
Новые Популярные
Межтекстовые Отзывы
Посмотреть все комментарии

Остались вопросы?

Я - Кондрашин Игорь, менеджер компании Voxlink. Хотите уточнить детали или готовы оставить заявку? Укажите номер телефона, я перезвоню в течение 3-х секунд.

VoIP оборудование


ближайшие курсы

10 доводов в пользу Asterisk

Распространяется бесплатно.

Asterisk – программное обеспечение с открытым исходным кодом, распространяется по лицензии GPL. Следовательно, установив один раз Asterisk вам не придется дополнительно платить за новых абонентов, подключение новых транков, расширение функционала и прочие лицензии. Это приближает стоимость владения станцией к нулю.

Безопасен в использовании.

Любое программное обеспечение может стать объектом интереса злоумышленников, в том числе телефонная станция. Однако, сам Asterisk, а также операционная система, на которой он работает, дают множество инструментов защиты от любых атак. При грамотной настройке безопасности у злоумышленников нет никаких шансов попасть на станцию.

Надежен в эксплуатации.

Время работы серверов некоторых наших клиентов исчисляется годами. Это значит, что Asterisk работает несколько лет, ему не требуются никакие перезагрузки или принудительные отключения. А еще это говорит о том, что в районе отличная ситуация с электроэнергией, но это уже не заслуга Asterisk.

Гибкий в настройке.

Зачастую возможности Asterisk ограничивает только фантазия пользователя. Ни один конструктор шаблонов не сравнится с Asterisk по гибкости настройки. Это позволяет решать с помощью Asterisk любые бизнес задачи, даже те, в которых выбор в его пользу не кажется изначально очевидным.

Имеет огромный функционал.

Во многом именно Asterisk показал какой должна быть современная телефонная станция. За многие годы развития функциональность Asterisk расширилась, а все основные возможности по-прежнему доступны бесплатно сразу после установки.

Интегрируется с любыми системами.

То, что Asterisk не умеет сам, он позволяет реализовать за счет интеграции. Это могут быть интеграции с коммерческими телефонными станциями, CRM, ERP системами, биллингом, сервисами колл-трекинга, колл-бэка и модулями статистики и аналитики.

Позволяет телефонизировать офис за считанные часы.

В нашей практике были проекты, реализованные за один рабочий день. Это значит, что утром к нам обращался клиент, а уже через несколько часов он пользовался новой IP-АТС. Безусловно, такая скорость редкость, ведь АТС – инструмент зарабатывания денег для многих компаний и спешка во внедрении не уместна. Но в случае острой необходимости Asterisk готов к быстрому старту.

Отличная масштабируемость.

Очень утомительно постоянно возвращаться к одному и тому же вопросу. Такое часто бывает в случае некачественного исполнения работ или выбора заведомо неподходящего бизнес-решения. С Asterisk точно не будет такой проблемы! Телефонная станция, построенная на Asterisk может быть масштабируема до немыслимых размеров. Главное – правильно подобрать оборудование.

Повышает управляемость бизнеса.

Asterisk дает не просто набор полезных функций, он повышает управляемость организации, качества и комфортности управления, а также увеличивает прозрачность бизнеса для руководства. Достичь этого можно, например, за счет автоматизации отчетов, подключения бота в Telegram, санкционированного доступа к станции из любой точки мира.

Снижает расходы на связь.

Связь между внутренними абонентами IP-АТС бесплатна всегда, независимо от их географического расположения. Также к Asterisk можно подключить любых операторов телефонии, в том числе GSM сим-карты и настроить маршрутизацию вызовов по наиболее выгодному тарифу. Всё это позволяет экономить с первых минут пользования станцией.