Делюсь полезным шаблоном для мониторинга RAID контроллеров LSI (Broadcom, Avago). Мониторим с помощью утилиты storcli. Шаблон делал сам.
Накаркал. Только недавно сделал шаблон для мониторинга LSI контроллеров в Linux и писал, что кто-то может и для Windows его проапгрейдить. И тут пришёл сервер с платой LSI на винде, пришлось доделывать шаблон самому.
Скачать шаблон для Zabbix 5.0: zabbix_lsi_v3.zip
Управление RAID контроллером LSI (Broadcom, Avago) с помощью StorCLI в Windows Server
Я проверял работу скриптов под Windows Server 2016 и Oracle Linux, но ничто не мешает это делать в прочих ОС. Нужно только установить утилиту storcli и её возможности вывода данных в виде JSON.
Шаблон использует низкоуровневое обнаружение LLD и находит:
- controllers — контроллеры
- logical disc — логические диски
- physical discs — физические диски в Enclosure и Backplane
- physical discs — физические диски без Enclosure и Backplane
- cv — кэш с батарейкой
- bbu — батарейки (не проверено)
Благодарности
Мой шаблон основан вот на этом шаблоне (автор Николай Куликов):
https://github.com/mykolq/zabbix_lsi_template
Однако, в этом шаблоне есть ряд досадных минусов:
- Выводятся данные только для одного контроллера. Остальные контролеры не видятся.
- Автор почему-то не стал мониторить температуру контроллеров и кэша.
- В системах с большим количеством дисков данные по ним тупо не помещаются в zabbix, слишком большой JSON.
Судя по комментариям у автора есть исправленная версия с поддержкой второго контроллера, но на гитхабе её нет.
В общем, я полез копаться в код и переделал там всё по-другому. Часть функционала оставил как было, например по батарейкам bbu. Не смог проверить, потому что у меня контроллеры с кэшом cv. Добавил автообнаружение контроллеров. Данные по физическим дискам вывел из короткой версии JSON, чтобы влезло в Zabbix. Добавил мониторинг температуры и дополнительные элементы данных.
Установка шаблона в Linux
Zabbix шаблон для мониторинга RAID контроллеров LSI в Linux
Установка шаблона в Windows
Качаем архив: zabbix_lsi_v3.zip
Импортируем шаблон zbx_lsi_json_lld_v3.xml.
В макросах шаблона можно отредактировать периодичность опроса данных:
- {$ADAP_DISCOVERY_PERIOD} — 1h. Периодичность автообнаружения контроллеров.
- {$ADAP_HISTORY_PERIOD} — 30d. Срок хранения истории контроллеров. У меня не работает, берётся значение из Zabbix. Оставил как в исходном шаблоне, вдруг в какй-то из версий будет работать.
- {$ADAP_REQUEST_PERIOD} — 10m. Периодичность опроса контроллеров, кэша, батареек.
- {$ADAP_THROTTLING_HB_PERIOD} — 3h. Срок тротлинга контроллера.
- {$ADAP_TREND_PERIOD} — 180d. Срок хранения трендов контроллера.
- {$BATTERY_HISTORY_PERIOD} — 30d. Срок хранения истории батареек и кэша.
- {$BATTERY_REQUEST_PERIOD} — 10m. Периодичность опроса батареек и кэша.
- {$BATTERY_TREND_PERIOD} — 180d. Срок хранения трендов батареек и кэша.
- {$INTERNAL_ITEMS_HISTORY_PERIOD} — 30d. Срок хранения истории JSON логических и физических дисков.
- {$LD_DISCOVERY_PERIOD} — 10m. Периодичность автообнаружения и опроса логических дисков.
- {$LD_HISTORY_PERIOD} — 30d. Срок хранения истории логических дисков.
- {$LD_REQUEST_PERIOD} — 10m. Периодичность опроса JSON логических дисков. Для просмотра всех параметров, которых нет в элементах данных.
- {$LD_THROTTLING_HB_PERIOD} — 3h. Срок тротлинга логических дисков.
- {$PD_DISCOVERY_PERIOD} — 10m. Периодичность автообнаружения и опроса физических дисков.
- {$PD_HISTORY_PERIOD} — 30d. Срок хранения истории физических дисков.
- {$PD_REQUEST_PERIOD} — 10m. Периодичность опроса JSON физических дисков. Для просмотра всех параметров, которых нет в элементах данных.
- {$PD_THROTTLING_HB_PERIOD} — 3h. Срок тротлинга физических дисков.
А также настроить граничные значения температур в градусах Цельсия:
- {$ADAP_CACHE_TEMP_CRIT} — 55. Критическая температура кэша.
- {$ADAP_CACHE_TEMP_AVERAGE} — 45. Высокая температура кэша.
- {$ADAP_CACHE_TEMP_WARNING} — 40. Повышенная температура кэша.
- {$ADAP_ROC_TEMP_CRIT} — 90. Критическая температура чипа.
- {$ADAP_ROC_TEMP_AVERAGE} — 80. Высокая температура чипа.
- {$ADAP_ROC_TEMP_WARNING} — 70. Повышенная температура чипа.
На сервере с контроллерами LSI устанавливаем утилиту storcli. Для удобства в архиве есть ZIP (007.1907.0000.0000_Unified_StorCLI-PUL.zip) и EXE (storcli64.exe) c текущей версией StorCLI. Утилита копируется в C:\zabbix\scripts.
Если у вас другой путь, то вам придётся править все скрипты.
Копируем lsi_raid_win.conf в папку с пользовательскими переменными, у меня это C:\zabbix\zabbix_agent2.conf.d\lsi_raid_win.conf. В конфигурации агента этот файл должен быть подключен.
Копируем папку со скриптами в C:\zabbix\scripts. В ней у нас:
- C:\zabbix\scripts\lsistorcli_cvsinfo.bat
- C:\zabbix\scripts\lsistorcli_ldinfo.bat
- C:\zabbix\scripts\lsistorcli_pdinfo.bat
- C:\zabbix\scripts\lsistorcli_pdinfo_ne.bat
- C:\zabbix\scripts\lsistorcli_bbuinfo.bat
- C:\zabbix\scripts\lsistorcli_ctlinfo.bat
Перезапускаем агент:
net stop "Zabbix Agent 2" && net start "Zabbix Agent 2"
Картинки
Источник:
https://internet-lab.ru/zabbix_lsi_win
Если вам понравилась статья, то ставьте 👍🏻 каналу.
Пишите комментарии, задавайте вопросы, подписывайтесь.