Настройка шаблона PostgreSQL на Zabbix 4.4
В Zabbix появился официальный Template DB PostgreSQL. В этой статье настроим его в Zabbix 4.4.

2. Скачиваем утилиту git и клонируем официальный репозиторий Zabbix, который находится на GitHub.
3. Переходим в каталог с шаблоном PostgreSQL.
Для PostgreSQL версии 10 и выше:
Для PostgreSQL версии 9.6 и ниже:
2. Скопируем каталог postgresql/ в каталог /var/lib/zabbix/. Если у вас в /var/lib/ отсутствует каталог zabbix/, то создайте его. Каталог postgresql / содержит файлы, необходимые для получения метрик из PostgreSQL.
3. Затем скопируем файл template_db_postgresql.conf в каталог конфигурации агента Zabbix /etc/zabbix/zabbix_agentd.d/ и перезапустите агента Zabbix.
4. Теперь отредактируем файл pg_hba.conf, чтобы разрешить подключение к Zabbix. Подробнее о файле pg_hba.conf: https://www.postgresql.org/docs/current/auth-pg-hba-conf.html.
Откройте файл:
Добавьте одну из строк (Если не понимаете зачем это нужно, то добавьте только первую строку.):
И наконец, выбираем "Monitoring" => "Latest data" => в "Hosts" выбираем сервер с PostgreSQL => нажимаем "Apply". Enjoy!

Если у вас все хорошо с английским, то рекомендую установить шаблон по официальному мануалу
https://github.com/zabbix/zabbix/tree/master/templates/db/postgresql
Тем не менее в моей статье учтены нюансы, которых нет по этой ссылке.
https://github.com/zabbix/zabbix/tree/master/templates/db/postgresql
Тем не менее в моей статье учтены нюансы, которых нет по этой ссылке.
Подготовка шаблона
1. Переходим в домашний каталог.cd ~
2. Скачиваем утилиту git и клонируем официальный репозиторий Zabbix, который находится на GitHub.
yum -y install git; git clone https://github.com/zabbix/zabbix.git
3. Переходим в каталог с шаблоном PostgreSQL.
cd zabbix/templates/db/postgresql/
Настройка шаблона для агента Zabbix
1. Создадим пользователя zbx_monitor только для чтения с правильным доступом к серверу PostgreSQL.Для PostgreSQL версии 10 и выше:
CREATE USER zbx_monitor WITH PASSWORD '<ВАШ_ПАРОЛЬ>' INHERIT; GRANT pg_monitor TO zbx_monitor;
Для PostgreSQL версии 9.6 и ниже:
CREATE USER zbx_monitor WITH PASSWORD '<ВАШ_ПАРОЛЬ>';
GRANT SELECT ON pg_stat_database TO zbx_monitor;
--Для сбора метрик WAL пользователь должен быть superuser.
ALTER USER zbx_monitor WITH SUPERUSER;
2. Скопируем каталог postgresql/ в каталог /var/lib/zabbix/. Если у вас в /var/lib/ отсутствует каталог zabbix/, то создайте его. Каталог postgresql / содержит файлы, необходимые для получения метрик из PostgreSQL.
cp -r postgresql/ /var/lib/zabbix/
3. Затем скопируем файл template_db_postgresql.conf в каталог конфигурации агента Zabbix /etc/zabbix/zabbix_agentd.d/ и перезапустите агента Zabbix.
cp template_db_postgresql.conf /etc/zabbix/zabbix_agentd.d/
4. Теперь отредактируем файл pg_hba.conf, чтобы разрешить подключение к Zabbix. Подробнее о файле pg_hba.conf: https://www.postgresql.org/docs/current/auth-pg-hba-conf.html.
Откройте файл:
vi /var/lib/pgsql/12/data/pg_hba.conf
Добавьте одну из строк (Если не понимаете зачем это нужно, то добавьте только первую строку.):
host all zbx_monitor 127.0.0.1/32 trust
host all zbx_monitor 0.0.0.0/0 md5
host all zbx_monitor ::0/0 md5
ПРИМЕЧАНИЕ
Если PostgreSQL установлен из репозитория PGDG, добавьте путь к pg_isready в переменную среды PATH для пользователя zabbix.
Для этого выполните команду:
ln -s /usr/pgsql-12/bin/pg_isready /usr/bin/pg_isready
Если этого не сделать, то Status: Ping всегда будет в состоянии Down.
Если PostgreSQL установлен из репозитория PGDG, добавьте путь к pg_isready в переменную среды PATH для пользователя zabbix.
Для этого выполните команду:
ln -s /usr/pgsql-12/bin/pg_isready /usr/bin/pg_isready
Если этого не сделать, то Status: Ping всегда будет в состоянии Down.
Добавление шаблона на фронтенде Zabbix
Считаю, что те, кому требуется снимать метрики с PostgreSQL итак знают как добавлять шаблоны. Поэтому опишу процесс кратко.- Заходим на страницу Zabbix;
- Переходим на страницу "Configuration" => "Host";
- Нажимаем на кнопку "Create host" или выбираем существующий хост;
- На странице создания/редактирования хоста выбираем вкладку "Templates" и и жмём на линк "Add";
- В "Group" из списка выбираем "Templates/Databases", выбираем шаблон "Template DB PostgreSQL", жмём кнопку "Select" и нажимаем кнопку "Update";
И наконец, выбираем "Monitoring" => "Latest data" => в "Hosts" выбираем сервер с PostgreSQL => нажимаем "Apply". Enjoy!
