Установка DBforBix для Zabbix под Debian

от автора

Приветствую!
Недавно заинтересовался мониторингом Oracle в Zabbix. Немного погуглив нашёл несколько вариантов, что бы выполнить поставленную задачу и, немного почитав решил остановиться на DBforBix. Но с данным демоном возникли небольшие сложности, т.к. в официальной вики доступна инструкция для RHEL, да и прилагаемом пакете init файл заточен под RHEL. Для меня это стало небольшой проблемой, т.к. мой Zabbix крутится на Debian. В связи с чем пришлось немного переделать код. Возможно это кому-нибудь пригодится.

1. Начальная установка

1. Для начала необходимо скачать сам пакет с официального сайта или с sourceforge.
2. После распаковать и перенести содержимое архива в папку /opt/dbforbix/.
3. Далее копируем файл /opt/dbforbix/init.d/dbforbix в /etc/init.d/dbforbix.
4. Даем права на выполнение для /etc/init.d/dbforbix и /opt/dbforbix/run.sh.
5. Переименовываем файл /opt/dbforbix/conf/config.props.sample в /opt/dbforbix/conf/config.props и /opt/dbforbix/conf/oraclequery.props.sample в /opt/dbforbix/conf/oraclequery.props
6. Кидаем необходимые библиотеки в папку /opt/dbforbix/lib/. В нашем случае нас интересует библиотека ojdbc6.jar. (Скачать все библиотеки можно здесь)

На этом инструкция заканчивается и теперь необходимо подправить пару файлов, для нормальной работоспособности демона в Debian.

2. Правка /etc/init.d/dbforbix

1. В начало файла вставляем что-то наподобии этого:

### BEGIN INIT INFO # Provides:             dbforbix # Required-Start:       $remote_fs $syslog # Required-Stop:        $remote_fs $syslog # Default-Start:        2 3 4 5 # Default-Stop: # Short-Description:    dbforbix ### END INIT INFO 

2. Комментируем строчку /etc/rc.d/init.d/functions и ниже прописываем:

/lib/lsb/init-functions 

3. Проверка активности интерфейса в RHEL:

# Get config. . /etc/sysconfig/network # Check that networking is up. [ "${NETWORKING}" = "no" ] && exit 0 

Меняем данные строки на:

state=`/sbin/ip link | awk '/eth0/{print $9}'` [ "${STATE}" = "DOWN" ] && exit 0 
3. Правка /opt/dbforbix/conf/config.props

Здесь все просто, меняем все параметры согласно инструкции и комментариям (в моем случае настройки касаются только БД Oracle):
ZabbixServerList=ZabbixServer1 — описание Zabbix серверов
ZabbixServer1.Address=10.10.10.10 — сервер Zabbix
ZabbixServer1.Port=10051 — порт сервера Zabbix
DatabaseList=ORACLEDB1 — описание подключаемых БД
ORACLEDB1.Url=jdbc:oracle:thin:@10.10.10.11:1521:name_of_sid — настройка коннекта к БД
ORACLEDB1.User=ZABBIX — пользователь (который мы укажем далее)
ORACLEDB1.Password=ZABBIX — пароль (который мы укажем далее)
ORACLEDB1.DatabaseType=oracle — тип БД

В общем все понятно. Единственное, что меня заинтересовало — строка

#pidFile DBforBIX.PidFile=./logs/orabbix.pid 

Почему orabbix я так и не понял, но переписал на

#pidFile DBforBIX.PidFile=./logs/dbforbix.pid 

т.к. в init.d все ссылается на данный файл, и соответственно создал файл dbforbix.pid в директории /opt/dbforbix/logs/.

4. Скрипт для Oracle

В официальной вики лежит скрипт, который прекрасно отрабатывается в Oracle 10 версии, для 11 — согласно вики требуются небольшие изменения.

 CREATE USER ZABBIX   IDENTIFIED BY <REPLACE WITH PASSWORD>   DEFAULT TABLESPACE SYSTEM   TEMPORARY TABLESPACE TEMP   PROFILE DEFAULT   ACCOUNT UNLOCK;   -– 2 Roles for ZABBIX   GRANT CONNECT TO ZABBIX;   GRANT RESOURCE TO ZABBIX;   ALTER USER ZABBIX DEFAULT ROLE ALL;   –- 5 System Privileges for ZABBIX   GRANT SELECT ANY TABLE TO ZABBIX;   GRANT CREATE SESSION TO ZABBIX;	   GRANT SELECT ANY DICTIONARY TO ZABBIX;   GRANT UNLIMITED TABLESPACE TO ZABBIX;  GRANT SELECT ANY DICTIONARY TO ZABBIX; 
Запуск DBforBix

Перед запуском необходимо выполнить следующие шаги:
1. Импортировать в Zabbix шаблон для Oracle, расположенный тут: /opt/dbforbix/template/template_oracle.xml
2. В Zabbix создать хост, имя которого должно совпадать с именем указанном в строке DatabaseList, в файле config.props. В моем случае имя хоста будет ORACLEDB1.
3. Активировать init.d скрипт командой:

insserv dbforbix 

4. Запустить DBforBix

/etc/init.d/dbforbix start 

Вот пожалуй и все. Единственное, для своей работы демон требует sun-java6-jre, для его установки на Debian 7 пришлось прописать старые репозитории и установить пакет оттуда.

ссылка на оригинал статьи http://habrahabr.ru/post/197746/


Комментарии

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *