Как удалить nagios с ubuntu
Nagios – популярная открытая система мониторинга. Она отслеживает серверы контролирует работу критически важных сервисов. Системы мониторинга типа Nagios являются важным инструментом для любой производственной среды, потому что, отслеживая метрики (время безотказной работы, использование ЦП или дискового пространства), вы можете устранять проблемы до их возникновения.
Данное руководство поможет установить Nagios 4 и настроить мониторинг ресурсов хоста через веб-интерфейс Nagios. Также вы научитесь настраивать NRPE (Nagios Remote Plugin Executor) в качестве агента на удаленном хосте.
Требования
- Два сервера Ubuntu 16.04, настроенные по этому мануалу, с частной сетью. Первый сервер будет использоваться для установки и запуска Nagios, а второй сервер будет настроен как удаленный хост, который будет отслеживаться сервером Nagios.
- На сервере 1 (Nagios) нужно установить Apache и PHP (все необходимые инструкции вы найдете в соответствующих разделах этого руководства).
- Как правило, Nagios работает за аппаратным брандмауэром или VPN. Если сервер Nagios доступен в интернете, вы должны защитить веб-интерфейс Nagios с помощью TLS. Для этого вам необходимо выполнить одно из следующих действий:
В этом руководстве предполагается, что на серверах есть частная сеть, поэтому мониторинг происходит по частной, а не по общедоступной сети. Если у вас нет частной сети, вы все равно можете следовать этому руководству, заменив все частные IP-адреса общедоступными IP-адресами.
1: Установка Nagios 4
Существует множество способов установки Nagios, но в данном руководстве рекомендуется установить Nagios и его компоненты из исходного кода, чтобы получить самые новые функции, обновления для системы безопасности и исправления ошибок.
Войдите на сервер 1 (на котором запущен Apache). Также этот сервер будет далее условно называться сервером Nagios.
Создайте пользователя nagios и группу nagcmd. Они будут использоваться для запуска процессов Nagios:
sudo useradd nagios
sudo groupadd nagcmd
Добавьте пользователя в группу:
sudo usermod -a -G nagcmd nagios
Поскольку Nagios и его компоненты будут собраны из исходного кода, сейчас нужно установить несколько библиотек разработки, включая компиляторы, заголовки разработки и OpenSSL.
Обновите индекс пакетов, чтобы загрузить последние версии необходимых пакетов:
sudo apt-get update
Теперь установите требуемые пакеты:
sudo apt-get install build-essential libgd2-xpm-dev openssl libssl-dev unzip
После этого можно установить Nagios. Загрузите исходный код последней стабильной версии Nagios Core. Перейдите на страницу загрузки Nagios и нажмите ссылку Skip to download под формой. Скопируйте адрес ссылки на последнюю стабильную версию, чтобы загрузить ее на сервер Nagios.
Загрузите релиз в домашний каталог:
tar zxf nagios-*.tar.gz
Перейдите в полученный каталог:
Прежде чем начать сборку Nagios, запустите сценарий configure, чтобы указать пользователя и группу для процесса Nagios (это nagios и nagcmd).
./configure --with-nagios-group=nagios --with-command-group=nagcmd
Команда configure вернет такой вывод:
Теперь запустите эти команды make, чтобы установить Nagios, сценарии инициализации и конфигурационные файлы по умолчанию:
sudo make install
sudo make install-commandmode
sudo make install-init
sudo make install-config
Apache будет обслуживать веб-интерфейс Nagios, поэтому скопируйте образец конфигурационного файла Apache в папку /etc/apache2/sites-available:
Чтобы выполнять внешние команды через веб-интерфейс Nagios, добавьте пользователя веб-сервера www-data в группу nagcmd:
sudo usermod -G nagcmd www-data
Система мониторинга Nagios установлена.
2: Установка плагина check_nrpe
Nagios контролирует удаленные хосты с помощью Nagios Remote Plugin Executor (или NRPE). NRPE состоит из двух частей:
- Плагин check_nrpe, который используется сервером Nagios.
- Демон NRPE, который запускается на удаленных хостах и отправляет данные на сервер Nagios.
Установите плагин check_nrpe на сервере Nagios.
Найдите URL для загрузки последней стабильной версии NRPE на сайте Nagios Exchange.
Загрузите его в домашний каталог с помощью curl:
Распакуйте архив NRPE:
tar zxf nrpe-*.tar.gz
Перейдите в полученный каталог:
Теперь соберите и установите плагин check_nrpe:
make check_nrpe
sudo make install-plugin
3: Настройка Nagios
Теперь нужно выполнить начальную настройку Nagios, которая включает в себя редактирование некоторых конфигурационных файлов и настройку Apache для обслуживания веб-интерфейса Nagios. Этот раздел нужно выполнить на сервере Nagios только один раз.
Откройте главный конфигурационный файл Nagios в текстовом редакторе:
sudo nano /usr/local/nagios/etc/nagios.cfg
Сохраните и закройте файл.
Теперь создайте каталог, в котором будет храниться конфигурационный файл для каждого сервера, который будет отслеживать Nagios:
sudo mkdir /usr/local/nagios/etc/servers
Откройте настройки контактов Nagios в текстовом редакторе:
sudo nano /usr/local/nagios/etc/objects/contacts.cfg
Найдите директиву email и укажите в ней свой адрес электронной почты:
Сохраните и закройте файл.
Затем добавьте в конфигурацию Nagios новую команду, которая позволяет использовать команду check_nrpe в определениях сервисов Nagios. Откройте файл /usr/local/nagios/etc/objects/commands.cfg в редакторе:
sudo nano /usr/local/nagios/etc/objects/commands.cfg
В конец файла добавьте определение новой команды check_nrpe:
.
define command command_name check_nrpe
command_line $USER1$/check_nrpe -H $HOSTADDRESS$ -c $ARG1$
>
Это определяет имя и задает параметры командной строки для выполнения плагина. Вы будете использовать эту команду в разделе 5.
Сохраните файл и выйдите из редактора.
Теперь настройте Apache для обслуживания пользовательского интерфейса Nagios. Включите модули Apache rewrite и cgi с помощью команды a2enmod:
sudo a2enmod rewrite
sudo a2enmod cgi
Используйте команду htpasswd, чтобы создать пользователя-администратора nagiosadmin, который может получить доступ к веб-интерфейсу Nagios:
Введите пароль в командной строке. Запомните этот пароль, так как он понадобится для доступа к веб-интерфейсу Nagios.
Примечание: Если вы создаете пользователя с другим именем (не nagiosadmin), вам нужно будет отредактировать /usr/local/nagios/etc/cgi.cfg и изменить все ссылки на имя nagiosadmin именем вашего пользователя.
Теперь создайте символическую ссылку на nagios.conf в каталоге sites-enabled. Это включит виртуальный хост Nagios.
sudo ln -s /etc/apache2/sites-available/nagios.conf /etc/apache2/sites-enabled/
Откройте конфигурационный файл Apache для Nagios.
sudo nano /etc/apache2/sites-available/nagios.conf
Если вы хотите ограничить доступ к веб-интерфейсу Nagios по IP-адресам (чтобы только определенные IP-адреса могли получить доступ к интерфейсу), найдите следующие две строки:
Order allow,deny
Allow from all
Затем найдите такие строки:
Order deny,allow
Deny from all
Allow from 127.0.0.1 your_ip_address
Эти строки встречаются в файле дважды, поэтому убедитесь, что вы изменили оба вхождения. Затем сохраните изменения и выйдите из редактора.
sudo systemctl restart apache2
Теперь можно настроить сервис для Nagios. Nagios не предоставляет файл Systemd для управления сервисом, поэтому его нужно создать самостоятельно. Создайте файл nagios.service и откройте его в редакторе:
sudo nano /etc/systemd/system/nagios.service
Введите следующее определение в файл. Это определение указывает, когда Nagios должен запускаться и где Systemd может найти приложение Nagios.
[Unit] Description=Nagios
BindTo=network.target
[Install] WantedBy=multi-user.target
[Service] Type=simple
User=nagios
Group=nagios
ExecStart=/usr/local/nagios/bin/nagios /usr/local/nagios/etc/nagios.cfg
Сохраните и закройте файл.
Запустите Nagios и добавьте его в автозагрузку:
sudo systemctl enable /etc/systemd/system/nagios.service
sudo systemctl start nagios
4: Веб-интерфейс Nagios
Введите учетные данные веб-интерфейса в появившемся всплывающем окне. Используйте имя nagiosadmin и укажите пароль, который вы создали ранее для этого пользователя.
После аутентификации вы увидите домашнюю страницу Nagios по умолчанию. Нажмите Hosts слева в панели навигации, чтобы увидеть, какие хосты мониторит Nagios.
Вы увидите, что на данный момент Nagios мониторит только localhost (то есть тот сервер, на котором находится установка Nagios).
5: Установка NRPE на хост
Давайте добавим новый хост, чтобы Nagios мог его отслеживать. Установите NRPE на удаленный хост, установите дополнительные плагины, а затем настройте сервер Nagios для мониторинга этого хоста (в разделе Требования этот сервер назывался сервером 2).
Войдите на сервер 2 (также он будет называться «сервер мониторинга»).
Создайте пользователя nagios для запуска агента NRPE.
sudo useradd nagios
NRPE нужно установить из исходного кода, а для этого вам понадобятся те же библиотеки разработки, которые вы устанавливали на сервере Nagios в разделе 1. Обновите индекс пакетов и установите необходимые библиотеки:
sudo apt-get update
sudo apt-get install build-essential libgd2-xpm-dev openssl libssl-dev unzip
NRPE требует, чтобы на удаленном хосте был установлен пакет Nagios Plugins. Установите этот пакет из исходного кода.
Найдите последнюю версию Nagios Plugins на странице загрузки Nagios. Скопируйте адрес ссылки на последнюю версию.
Загрузите Nagios Plugins в домашний каталог:
Распакуйте архив Nagios Plugins:
tar zxf nagios-plugins-*.tar.gz
Перейдите в полученный каталог:
Прежде чем приступить к сборке Nagios Plugins, настройте программу для использования группы и пользователя nagios, а также включите поддержку OpenSSL:
./configure --with-nagios-user=nagios --with-nagios-group=nagios --with-openssl
Затем установите его:
sudo make install
Затем установите NRPE. Найдите URL-адрес для загрузки последней стабильной версии NRPE на сайте Nagios Exchange. Загрузите последнюю стабильную версию NRPE в домашний каталог сервера мониторинга с помощью curl:
tar zxf nrpe-*.tar.gz
Перейдите в этот каталог:
Чтобы настроить NRPE, укажите пользователя и группу Nagios, а также включите поддержку SSL.
./configure --enable-command-args --with-nagios-user=nagios --with-nagios-group=nagios --with-ssl=/usr/bin/openssl --with-ssl-lib=/usr/lib/x86_64-linux-gnu
Затем соберите и установите NRPE и запустите сценарий:
make all
sudo make install
sudo make install-config
sudo make install-init
Обновите конфигурационный файл NRPE:
sudo nano /usr/local/nagios/etc/nrpe.cfg
Найдите директиву allowed_hosts и добавьте внутренний IP-адрес сервера Nagios в список через запятую:
Теперь NRPE может принимать подключения от сервера Nagios через его внутренний IP-адрес.
Сохраните и закройте файл. Запустите NRPE:
sudo systemctl start nrpe.service
Запросите состояние сервиса, чтобы убедиться, что он работает:
sudo systemctl status nrpe.service
Oct 16 07:10:00 nagios systemd[1]: Started Nagios Remote Plugin Executor.
Oct 16 07:10:00 nagios nrpe[14653]: Starting up daemon
Oct 16 07:10:00 nagios nrpe[14653]: Server listening on 0.0.0.0 port 5666.
Oct 16 07:10:00 nagios nrpe[14653]: Server listening on :: port 5666.
Oct 16 07:10:00 nagios nrpe[14653]: Listening for connections on port 5666
Oct 16 07:10:00 nagios nrpe[14653]: Allowing connections from: 127.0.0.1. 1,207.154.249.232
Затем откройте в брандмауэре порт 5666. Если вы используете UFW, настройте его для поддержки TCP-подключений по порту 5666:
sudo ufw allow 5666/tcp
Теперь вы можете проверить связь с удаленным сервером NRPE. Выполните следующую команду на сервере Nagios:
/usr/local/nagios/libexec/check_nrpe -H remote_host_ip
NRPE v3.2.1
Теперь настройте базовые метрики, которые будет проверять Nagios.
Во-первых, нужно настроить мониторинг использования диска на этом сервере. Введите команду df –h, чтобы найти имя корневой файловой системы. Вы будете использовать это имя файловой системы в конфигурации NRPE:
df -h /
Filesystem Size Used Avail Use% Mounted on
udev 490M 0 490M 0% /dev
tmpfs 100M 3.1M 97M 4% /run
/dev/vda1 29G 1.4G 28G 5% /
tmpfs 497M 0 497M 0% /dev/shm
tmpfs 5.0M 0 5.0M 0% /run/lock
tmpfs 497M 0 497M 0% /sys/fs/cgroup
/dev/vda15 105M 3.4M 102M 4% /boot/efi
tmpfs 100M 0 100M 0% /run/user/0
Узнайте, какая файловая система связана с /. На сервере это, вероятно, /dev/vda1.
Откройте файл /usr/local/nagios/etc/nrpe.cfg в редакторе:
sudo nano /usr/local/nagios/etc/nrpe.cfg
Конфигурационный файл NRPE очень длинный, в нем много комментариев. Вот строки, которые вам нужно будет найти и изменить:
- server_address: укажите внутренний IP-адрес сервера мониторинга.
- command[check_hda1]: вместо /dev/hda1 укажите имя корневой файловой системы.
Найдите эти параметры и измените их соответствующим образом:
.
server_address=monitored_server_private_ip
.
command[check_vda1]=/usr/lib/nagios/plugins/check_disk -w 20% -c 10% -p /dev/vda1
.
Сохраните и закройте файл.
sudo systemctl restart nrpe.service
Повторите действия этого раздела на каждом новом сервере мониторинга.
После того, как вы закончите установку и настройку NRPE на хостах, которые хотите отслеживать, вам нужно добавить эти хосты в конфигурацию сервера Nagios.
6: Мониторинг хостов с помощью Nagios
Чтобы мониторить хосты с помощью Nagios, нужно добавить конфигурационные файлы для каждого хоста и указать, что их нужно отслеживать. Затем можно просмотреть эти хосты в веб-интерфейсе Nagios.
На сервере Nagios в /usr/local/nagios/etc/servers/ создайте новый конфигурационный файл для каждого из удаленных хостов, которые вы хотите отслеживать. Замените monitored_server_host_name на имя вашего хоста:
sudo nano /usr/local/nagios/etc/servers/your_monitored_server_host_name.cfg
Добавьте следующее определение хоста, заменив значение host_name именем удаленного хоста, значение alias описанием хоста, а значение address – внутренним IP-адресом удаленного хоста:
define host use linux-server
host_name your_monitored_server_host_name
alias My client server
address your_monitored_server_private_ip
max_check_attempts 5
check_period 24x7
notification_interval 30
notification_period 24x7
>
С такими настройками Nagios сможет только сообщить, включен ли хост.
Добавьте еще несколько сервисов, которые нужно мониторить.
Чтобы отслеживать использование CPU, добавьте:
define service use generic-service
host_name your_monitored_server_host_name
service_description CPU load
check_command check_nrpe!check_load
>
Благодаря директиве use generic-service Nagios может наследовать значения шаблона сервиса generic-service, который предопределен в Nagios.
Затем добавьте этот блок, чтобы настроить мониторинг использования диска:
define service use generic-service
host_name your_monitored_server_host_name
service_description /dev/vda1 free space
check_command check_nrpe!check_vda1
>
Сохраните и закройте файл. Перезапустите сервис Nagios:
sudo systemctl restart nagios
Через несколько минут Nagios проверит новые хосты, и вы увидите их в веб-интерфейсе. Нажмите Services в панели навигации, чтобы просмотреть все контролируемые хосты и сервисы.
Заключение
Настроив мониторинг хостов и некоторых сервисов, определите, какие сервисы имеют решающее значение в работе сервера, и добавьте их в список. Также можно настроить извещения; к примеру, Nagios может сообщить о том, что использование диска достигло критической отметки или что веб-сайт не работает. Это позволяет вовремя устранить подобные проблемы.
Установка и удаление программ одна из самых важных вещей для пользователя компьютера. Поскольку нам нужно как нибудь получать новые, нужные программы, а также удалять лишние. Но удаление пакетов в Ubuntu имеет некоторые тонкости. После удаления могут остаться зависимости, пакеты установленные, как рекомендованные, а также конфигурационные файлы.
В этой статье мы разберем как удалить deb пакет Ubuntu, при чем удалить чисто, так, чтобы после него не осталось следов в системе. Также поговорим о полном удалении PPA, поскольку много пакетов, которых нет в официальных репозиториях мы устанавливаем из PPA.
Как удалить пакет Ubuntu
Самый простой способ удалить пакет Ubuntu, это воспользоватся одной из графических утилит, поставляемых специально для этого, например Synaptic или Центр приложений Ubuntu. По сути это делается в пару кликов. Сначала рассмотрим порядок действий в Центре приложений Ubuntu.
Запустить центр приложений вы можете из панели значков Unity:
Список всех установленных пакетов находится на вкладке Установлено, здесь приложения рассортированы по категориям:
Чтобы удалить пакет Ubuntu, достаточно кликнуть по нему левой кнопкой мыши, и когда появляться доступные действия нажать кнопку Удалить:
Для завершения нужно будет подтвердить удаление и ввести пароль.
Пакет удален, но не совсем так, как нам хотелось бы. Но об этом позже.
Дальше рассмотрим пакетный менеджер Synaptic. Это как ни как стороннее программное обеспечение, но многие его используют из-за большого функционала и удобного интерфейса. Если программа еще не установлена, ее нужно установить с помощью центра приложений или выполнив в терминале:
sudo apt install synaptic
Запустить программу можно через терминал, выполнив команду:
Посмотреть установленные пакеты вы можете выбрав вкладку состояние, а затем выбрав Установленные:
Удалить deb ubuntu вы можете просто нажав правой кнопкой мыши и в контекстном меню на нужном пакете и выбрав отметить для удаления или отметить для полного удаления:
Программа покажет, какие еще пакеты будут удалены, это те пакеты, которые зависят от нашего пакета:
Теперь, чтобы завершить удаление, осталось нажать кнопку Применить:
Теперь программа покажет какие пакеты будут удалены. И пойдет процесс удаления:
Просто удаление и полное удаление отличается только тем, что при полном удалении удаляются конфигурационные файлы. Но проблема этих инструментов в том, что пакеты установленные как зависимости и рекомендованные к программе не удаляются и остаются в системе. Такое поведение наблюдается как в Synaptic, так и в Центре приложений Ubuntu. Поэтому мы переходим к описанию самого гибкого способа - удаление пакетов Ubuntu в терминале.
Как удалить пакет Ubuntu в терминале
В новых версиях Ubuntu для управления пакетами, а в том числе и удаления можно использовать новый менеджер пакетов - apt. Команда удаления выглядит таким образом:
sudo apt remove имя_пакета
Будет выполнено полное удаление пакета, включая конфигурационные файлы и зависимости, только рекомендованные программы останутся. Если вы хотите использовать apt-get чтобы удалить deb ubuntu, то порядок действий немного другой. Для обычного удаления пакета выполните:
sudo apt-get remove имя_пакета
Для удаления пакета вместе с его конфигурационными файлами, выполните:
sudo apt-get purge имя_пакета
А чтобы, также удалить зависимости, установленные вместе с пакетом, нужно после одной из предыдущих команд выполнить:
sudo apt autoremove
Будут удаленны не только явно указанные зависимости, но и программы установленные как рекомендованные.
Ну с основами разобрались, теперь перейдем к более сложным ситуациям. Что если вы устанавливали программу из deb файла и теперь не знаете точно, как называется ее пакет, чтобы удалить?
Это очень просто узнать, например по исполняемому файлу, допустим исполняемый файл программы TimeShift находится по адресу /usr/bin/timeshift, теперь узнаем ее пакет:
sudo dpkg -S /usr/bin/timeshift
Как видите, пакет так и называется - timeshift. Теперь можно удалить программу Ubuntu, одним из выше описанных способов.
Очень часто мы устанавливаем недостающее нам программное обеспечение из PPA, но не все эти пакеты нужны нам на протяжении долгого времени, а при обновлении системы, могут даже вызвать ошибки. Так как же удалить все пакеты установленные из PPA? Для этого есть специальная утилита: ppa-purge.
Если она еще не установлена, устанавливаем командой:
sudo apt install ppa-purge
Теперь, чтобы удалить все пакеты установленные из определенного ppa используйте:
sudo ppa-purge -i ppa:владелец_ppa/имя_ppa
Обратите внимание на ppa:владелец_ppa/имя_ppa - обычно в таком формате записываются все PPA: протокол:владелец/имя.
Узнать список репозиториев можно в программе источники приложений:
Такой командой можно одним махом удалить пакеты ubuntu, установленные из ppa:
find /etc/apt/sources.list.d -type f -name "*.list" -print0 | \
while read -d $'\0' file; do awk -F/ '/deb / && /ppa\.launchpad\.net/ ' "$file"; done
Если вы устанавливали приложение из исходных кодов, то удалить его намного сложнее, потому что оно не контролируется менеджером пакетов, и соответственно система не знает какие файлы ему принадлежат.
Но все же способ есть, обычно, разработчики в файле сценариев makefile, кроме цели install реализуют цель uninstall, которая дозволяет выполнить обратное действие.
Поэтому если у вас осталась папка с исходным кодом той программы можно просто перейти в нее и выполнить make uninstall чтобы удалить приложение Ubuntu:
cd /папка/с/исходниками
$ sudo make uninstall
Выводы
В этой статье мы рассмотрели все, что поможет вам удалить приложение Ubuntu. При чем удалить полностью, а не только файлы программы. Если у вас остались вопросы, пишите в комментариях.
Nagios - это один из самых распространенных инструментов мониторинга серверов Linux и Windows с открытым исходным кодом. С помощью него вы сможете следить за выполнением различных приложений и сервисов удаленно, через веб-интерфейс. Nagios также может контролировать маршрутизаторы и другие сетевые устройства.
С помощью Nagios вы можете отслеживать основные параметры сервера, такие как нагрузка на процессор, использование памяти и т д. Все это доступно в веб-интерфейсе, для получения доступа к которому нужно пройти простую аутентификацию. В этой статье мы рассмотрим как выполняется установка Nagios Ubuntu, а также настройка этой программы.
Установка Nagios в Ubuntu
Есть несколько способов установить Nagios Ubuntu 16.04. Вы можете воспользоваться PPA или устанавливать с помощью архива, загруженного на официальном сайте. На данный момент самая последняя версия - 4.3. В PPA доступна только 4.2, поэтому мы рассмотрим ручную установку с помощью архива.
Но перед тем как мы перейдем к установке необходимо обновить систему и установить все необходимые компоненты для сборки программы:
sudo apt update
sudo apt install build-essential apache2 php7.0 openssl perl make php7.0-gd libgd2-xpm-dev libapache2-mod-php7.0 libperl-dev libssl-dev daemon wget apache2-utils unzip
Затем нужно создать группу и пользователя, от имени которых будет запускаться Nagios, а также команды оболочки, выполненные в веб-интерфейсе:
sudo useradd nagios
$ sudo groupadd nagcmd
Добавьте пользователя nagios и пользователя, от имени которого запускается Apache в группу nagcmd:
sudo usermod -a -G nagcmd nagios
$ sudo usermod -a -G nagcmd www-data
Затем нам нужно скачать исходные коды nagios. Это можно сделать с помощью команды терминала, но поскольку мы хотим получить самую новую версию, то лучше зайти на официальный сайт и скачать.
Сначала кликните по пункту "Nagios Core", затем пролистайте вниз и нажмите "Download":
На этом этапе вы можете заполнить информацию о себе, или пропустить, нажав "Skip download":
Осталось выбрать версию, например, 4.3.2. После того как загрузка будет завершена перейдите в папку с загрузками и распакуйте архив:
/Загрузки/
$ tar -zxvf /tmp/nagios-4.3.2.tar.gz
Теперь можно переходить к компиляции nagios. Для этого нужно выполнить такие команды:
Настройка Nagios в Ubuntu
Все конфигурационные файлы программы будут размещены установщиком в /usr/local/nagios/etc/. Настройки по умолчанию позволяют запустить Nagios, но нам нужно внести еще несколько изменений. Откройте файл contact.cfg и измените электронный адрес, на который будут приходить оповещения:
sudo vi /usr/local/nagios/etc/objects/contacts.cfg
Для работы веб-интерфейса необходимо создать пароль пользователя nagiosadmin с помощью htpasswd, без него вы просто не сможете войти в интерфейс:
Наконец, для корректной работы нужно внести несколько настроек для веб-сервера. Включите модуль cgi:
sudo a2enmod cgi
sudo service apache2 restart
Для получения дополнительных возможностей nagios вы можете установить набор плагинов. Для этого сначала скачайте его:
Теперь распакуйте архив и перейдите в папку с ним:
tar -zxvf /tmp/nagios-plugins-2.1.1.tar.gz
$ cd /tmp/nagios-plugins-2.1.1/
Для компиляции модулей выполните:
./configure --with-nagios-user=nagios --with-nagios-group=nagios
$ make
$ make install
Модули установлены в папку с Nagios, теперь проверьте правильность конфигурации:
/usr/local/nagios/bin/nagios -v /usr/local/nagios/etc/nagios.cfg
Для автоматического запуска создадим Unit файл для systemd:
sudo vi /etc/systemd/system/nagios.service
[Unit]
Description=Nagios
BindTo=network.target
[Service]
User=nagios
Group=nagios
Type=simple
ExecStart=/usr/local/nagios/bin/nagios /usr/local/nagios/etc/nagios.cfg
Запуск Nagios
Почти все готово, осталось запустить сервис и начать использовать. Для запуска сервиса наберите:
sudo systemctl stat nagios
Чтобы открыть веб-интерфейс nagios будет достаточно набрать ip адрес и url nagios в браузере. Если вы устанавливали все это на локальном компьютере, то используйте:
Сразу после открытия странички вам нужно будет ввести имя пользователя nagiosadmin и пароль, который вы задали для него ранее. После этого можете пользоваться всеми возможностями программы:
Выводы
В этой статье мы рассмотрели как выполняется настройка nagios 4, а также полная установка последней версии в операционной системе Ubuntu. Несмотря на то, что, на первый взгляд, все кажется сложным, процесс достаточно простой. Теперь вы можете осуществлять мониторинг nagios ubuntu 16.04. Надеюсь, эта информация была полезной для вас.
How To Install and Configure Nagios on Ubuntu 18.04
Это руководство проведет вас через шаги, необходимые для установки и настройки последней версии Nagios Core в Ubuntu 18.04.
В случае сбоя или неоптимальной производительности Nagios будет отправлять уведомления с помощью различных методов.
Более старая версия Nagios (версия 3) доступна в репозитории программного обеспечения Ubuntu и может быть легко установлена с помощью apt install nagios3 .
Прежде, чем приступить
Прежде чем продолжить это руководство, убедитесь, что вы вошли в систему как пользователь с привилегиями sudo .
Обновите свою систему Ubuntu и установите следующие пакеты, необходимые для загрузки и компиляции основного приложения Nagios и плагинов Nagios:
Установка Nagios в Ubuntu
Следующие шаги описывают, как установить последнюю версию Nagios Core из исходного кода.
1. Скачивание Nagios
Мы собираемся загрузить исходный код Nagios в /usr/src каталог, который является обычным местом для размещения исходных файлов, перейдите в каталог с помощью:
Загрузите последнюю версию Nagios из репозитория проекта Github с помощью следующей команды wget :
Когда загрузка завершится, извлеките tar-файл с помощью:
Перед тем, как продолжить следующие шаги, убедитесь , что вы измените в исходный каталог Nagios, набрав:
2. Компиляция Nagios
Чтобы запустить процесс сборки, запустите configure скрипт, который выполнит ряд проверок, чтобы убедиться, что все зависимости в вашей системе присутствуют:
Теперь вы можете запустить процесс компиляции с помощью make команды:
3. Создание пользователя и группы Nagios
Следующая команда создаст нового системного nagios пользователя и группу:
Добавьте www-data пользователя Apache в nagios группу:
4. Установите двоичные файлы Nagios.
Выполните следующую команду, чтобы установить двоичные файлы, CGI и HTML Nagios:
Вы должны увидеть следующий результат:
5. Создание каталога внешних команд
Nagios может обрабатывать команды из внешних приложений. Создайте каталог внешних команд и установите соответствующие разрешения, набрав:
6. Установите файлы конфигурации Nagios.
Установите образцы файлов конфигурации Nagios с помощью:
7. Установите файлы конфигурации Apache.
Приведенная ниже команда установит файлы конфигурации веб-сервера Apache:
Убедитесь, что модули Apache rewrite и cgi включены:
8. Создание файла модуля Systemd
Следующая команда устанавливает файл модуля systemd, а также настраивает службу nagios для запуска при загрузке.
9. Создание учетной записи пользователя
Чтобы иметь доступ к веб-интерфейсу Nagios, вам необходимо создать пользователя-администратора с именем nagiosadmin
Используйте следующую htpasswd команду для создания пользователя с именем nagiosadmin
Вам будет предложено ввести и подтвердить пароль пользователя.
Перезапустите службу Apache, чтобы изменения вступили в силу:
10. Настройка межсетевого экрана.
Брандмауэр защитит ваш сервер от нежелательного трафика.
Если на вашем сервере не настроен брандмауэр, вы можете ознакомиться с нашим руководством о том, как настроить брандмауэр с ufw на ubuntu.
Откройте порты Apache, набрав:
Установка плагинов Nagios
Вернитесь в /usr/src каталог и загрузите последнюю версию плагинов Nagios из репозитория Github проекта :
После завершения загрузки извлеките tar-файл, набрав:
Перейдите в исходный каталог плагинов:
Выполните следующие команды одну за другой, чтобы скомпилировать и установить плагины Nagios:
Запуск Nagios
Теперь, когда установлены и Nagios, и его плагины, запустите службу Nagios с помощью следующей команды:
Чтобы убедиться, что Nagios запущен, проверьте статус службы, набрав:
Результат должен выглядеть примерно так, как показано ниже, показывая, что служба Nagios активна и работает.
Доступ к веб-интерфейсу Nagios
Чтобы получить доступ к веб-интерфейсу Nagios, откройте свой любимый браузер и введите доменное имя вашего сервера или общедоступный IP-адрес, а затем /nagios :
Введите nagiosadmin учетные данные пользователя, и вы будете перенаправлены на домашнюю страницу Nagios по умолчанию, как показано на изображении ниже:
Заключение
Вы успешно установили последнюю версию Nagios из исходного кода в своей системе Ubuntu.
Теперь вам следует проверить документацию Nagios и узнать больше о том, как настроить и использовать Nagios.
Данное руководство поможет установить популярную открытую систему мониторинга Nagios 4 на сервер Ubuntu 14.04, а также выполнить базовую настройку мониторинга ресурсов хоста. Кроме того, в руководстве показано, как настроить Nagios Remote Plugin Executor (NRPE) в качестве агента на удалённых хостах для мониторинга их ресурсов.
Система Nagios позволяет отслеживать ресурсы сервера и работу основных сервисов. В целом системы мониторинга являются важным инструментом для любой среды производства.
Примечание: Аналогичное руководство для CentOS можно найти по этой ссылке.
Требования
- Предварительно настроенный сервер Ubuntu 14.04.
- Права суперпользователя (подробнее – здесь).
- Заранее установленный стек LAMP (инструкции по установке можно найти здесь).
- Частная сеть; если ваш сервер не поддерживает частную сеть, просто замените ссылки на внутренний IP-адрес внешним IP-адресом.
Установка Nagios 4
Создание пользователя и группы Nagios
Создайте пользователя и группу для запуска процесса Nagios; в данном руководстве пользователь называется nagios, а группа nagcmd. Создайте их и добавьте пользователя в группу.
sudo useradd nagios
sudo groupadd nagcmd
sudo usermod -a -G nagcmd nagios
Установка зависимостей
После этого нужно установить несколько библиотек для разработки, чтобы собрать Nagios Core из исходного кода, и apache2-utils для настройки интерфейса Nagios.
Обновите список пакетов системы:
sudo apt-get update
sudo apt-get install build-essential libgd2-xpm-dev openssl libssl-dev xinetd apache2-utils unzip
Установка Nagios Core
Загрузите последний стабильный релиз Nagios Core. Откройте загрузочную страницу сайта, кликните Skip to download и загрузите ссылку на стабильный релиз.
Примечание: В руководстве используется версия Nagios 4.1.1.
Загрузите пакет в домашний каталог:
tar xvf nagios-*.tar.gz
Откройте полученный каталог:
./configure --with-nagios-group=nagios --with-command-group=nagcmd
Затем установите Nagios, сценарии инициализации и образцы конфигурационных файлов:
Чтобы иметь возможность запускать внешние команды через веб-интерфейс Nagios, нужно добавить пользователя www-data в группу nagcmd:
sudo usermod -G nagcmd www-data
Установка плагинов Nagios
Последний релиз Nagios Plugins можно найти по этой ссылке. Скопируйте ссылку на последний стабильный релиз и загрузите пакет в домашний каталог.
Примечание: В руководстве используется версия Nagios Plugins 2.1.1.
Распакуйте архив Nagios Plugins.
tar xvf nagios-plugins-*.tar.gz
Откройте полученный каталог:
Запустите настройку Nagios Plugins перед сборкой пакетов.
./configure --with-nagios-user=nagios --with-nagios-group=nagios --with-openssl
Скомпилируйте Nagios Plugins:
Установите полученный пакет:
sudo make install
Установка NRPE
Откройте загрузочную страницу сайта, найдите последний стабильный релиз NRPE и загрузите его в домашний каталог.
Примечание: В руководстве используется NRPE 2.15.
Распакуйте архив NRPE:
tar xvf nrpe-*.tar.gz
Перейдите в полученный каталог:
Чтобы настроить NRPE, запустите команду:
./configure --enable-command-args --with-nagios-user=nagios --with-nagios-group=nagios --with-ssl=/usr/bin/openssl --with-ssl-lib=/usr/lib/x86_64-linux-gnu
После этого соберите и установите NRPE и сценарий xinetd:
make all
sudo make install
sudo make install-xinetd
sudo make install-daemon-config
Откройте скрипт запуска xinetd в текстовом редакторе:
sudo vi /etc/xinetd.d/nrpe
В строку only_from добавьте внутренний IP-адрес сервера Nagios:
only_from = 127.0.0.1 10.132.224.168
Примечание: Укажите свой правильный IP-адрес.
Сохраните и закройте файл. Теперь взаимодействовать с NRPE сможет только сервер Nagios.
sudo service xinetd restart
Установка Nagios 4 успешно завершена. Теперь нужно настроить систему.
Настройка Nagios 4
Откройте главный конфигурационный файл Nagios в текстовом редакторе:
sudo vi /usr/local/nagios/etc/nagios.cfg
Найдите и раскомментируйте следующую строку:
Сохраните и закройте файл.
Создайте каталог для хранения конфигурационных файлов отслеживаемых серверов.
sudo mkdir /usr/local/nagios/etc/servers
Откройте конфигурационный файл contacts в текстовом редакторе:
sudo vi /usr/local/nagios/etc/objects/contacts.cfg
Найдите директиву email и укажите в ней свой адрес электронной почты.
email nagios@localhost ; <<***** CHANGE THIS TO YOUR EMAIL ADDRESS ******
Сохраните и закройте файл.
Настройка команды check_nrpe
Добавьте в настройки Nagios новую команду:
sudo vi /usr/local/nagios/etc/objects/commands.cfg
Добавьте в конец файла следующий код:
define command command_name check_nrpe
command_line $USER1$/check_nrpe -H $HOSTADDRESS$ -c $ARG1$
>
Сохраните и закройте файл. Теперь вы сможете использовать команду check_nrpe в определении серверов Nagios.
Настройка Apache
Включите модули rewrite и cgi:
sudo a2enmod rewrite
sudo a2enmod cgi
Используйте htpasswd, чтобы создать пользователя по имени nagiosadmin для доступа к веб-интерфейсу Nagios.
Введите пароль. Запомните эти учётные данные, поскольку они пригодятся для работы с веб-интерфейсом Nagios.
Примечание: Если назвать этого пользователя не nagiosadmin, то нужно будет отредактировать файл /usr/local/nagios/etc/cgi.cfg и во всех ссылках на nagiosadmin указать другое имя пользователя.
После этого создайте символьную ссылку на nagios.conf в sites-enabled:
sudo ln -s /etc/apache2/sites-available/nagios.conf /etc/apache2/sites-enabled/
Теперь система Nagios готова к запуску. Не забудьте перезапустить Apache:
sudo service nagios start
sudo service apache2 restart
Чтобы настроить автозапуск Nagios, введите:
sudo ln -s /etc/init.d/nagios /etc/rcS.d/S99nagios
Ограничение доступа по IP-адресу (опционально)
Чтобы разрешить доступ только определённым IP-адресам, отредактируйте конфигурацию Apache:
sudo vi /etc/apache2/sites-available/nagios.conf
Найдите и закомментируйте следующие строки:
Order allow,deny
Allow from all
Затем раскомментируйте следующие строки и добавьте IP-адреса или диапазоны IP-адресов (через пробел), которые будут иметь доступ к серверу, в директиву Allow from:
Примечание: Поскольку эти строки встречаются в конфигурационном файле два раза, нужно повторить эти инструкции дважды.
Сохраните и закройте файл.
Запустите Nagios и перезапустите Apache, чтобы обновить настройки:
sudo service nagios restart
sudo service apache2 restart
Веб-интерфейс Nagios
Откройте браузер и перейдите к Nagios по этой ссылке:
Примечание: Укажите в ссылке свой IP-адрес.
Веб-сервер Apache использует htpasswd, потому нужно ввести учётные данные пользователя nagiosadmin.
Пройдя аутентификацию, вы получите доступ к домашней странице Nagios. Чтобы просмотреть список серверов, отслеживаемых Nagios, откройте Hosts в левой панели управления.
Как видите, на данный момент Nagios мониторит только localhost.
Мониторинг хоста при помощи NRPE
Данный раздел покажет, как добавить в настройки мониторинга Nagios новый сервер.
Примечание: Если вы хотите добавить несколько серверов, повторите эти инструкции на каждом из них.
Войдите на сервер, который нужно добавить в список отслеживаемых, и обновите apt-get:
sudo apt-get update
Затем установите Nagios Plugins и NRPE.
sudo apt-get install nagios-plugins nagios-nrpe-server
Настройка хостов
Откройте конфигурационный файл NRPE в текстовом редакторе:
sudo vi /etc/nagios/nrpe.cfg
Найдите директиву allowed_hosts и добавьте в конец внутренний IP-адрес сервера Nagios (через запятую).
Сохраните и закройте файл. Теперь NRPE будет принимать запросы от сервера Nagios через внутренний IP-адрес.
Настройка команд NRPE
Уточните имя файловой системы root (это один из компонентов, который будет отслеживаться):
Используйте имя файловой системы в конфигурации NRPE для мониторинга использования диска (/dev/vda). Откройте nrpe.cfg в редакторе:
sudo vi /etc/nagios/nrpe.cfg
Конфигурационный файл NRPE очень длинный и содержит много закомментированных строк. Вам понадобятся только следующие строки:
- server_address: Укажите внутренний IP-адрес хоста.
- allowed_hosts: Укажите внутренний IP-адрес сервера Nagios.
- command[check_hda1]: Замените/dev/hda1 именем файловой системы root.
В результате эти строки должны иметь такой вид:
server_address=client_private_IP
allowed_hosts=nagios_server_private_IP
command[check_hda1]=/usr/lib/nagios/plugins/check_disk -w 20% -c 10% -p /dev/vda
Обратите внимание: файл содержит несколько других строк command, которые может использовать Nagios. NRPE прослушивает порт 5666 (строка server_port=5666). Если этот порт заблокирован брандмауэром, не забудьте открыть его.
Сохраните и закройте файл.
Перезапустите NRPE, чтобы обновить настройки:
sudo service nagios-nrpe-server restart
После этого нужно добавить хост в настройки сервера Nagios.
Добавление хоста в настройки Nagios
Перейдите на сервер Nagios и создайте новый конфигурационный файл для хоста в /usr/local/nagios/etc/servers/.
sudo vi /usr/local/nagios/etc/servers/yourhost.cfg
Примечание: Вместо yourhost укажите имя своего хоста.
Добавьте в файл следующий код, заменив значение host_name именем удалённого хоста (в данном примере это web-1), значение alias – описанием хоста, а address – внутренним IP-адресом удалённого хоста.
define host use linux-server
host_name yourhost
alias My first Apache server
address 10.132.234.52
max_check_attempts 5
check_period 24x7
notification_interval 30
notification_period 24x7
>
Теперь Nagios будет мониторить данный сервер. Однако система будет отслеживать только состояние удалённого хоста (включен он или отключен). Если этого достаточно, сохраните и закройте файл. Если вы хотите мониторить отдельные сервисы на удалённом хосте, не закрывайте файл.
Ниже приведены примеры настройки отслеживания сервисов. Просто выберите сервис, который вы хотите отслеживать, и добавьте в файл предложенный блок настроек. Имейте в виду: значение команды check_command определяет, что именно будет отслеживаться.
define service use generic-service
host_name yourhost
service_description PING
check_command check_ping!100.0,20%!500.0,60%
>
SSH (notifications_enabled со значением 0 отключает уведомления):
define service use generic-service
host_name yourhost
service_description SSH
check_command check_ssh
notifications_enabled 0
>
Директива use generic-service просто наследует значения шаблона generic-service, установленного по умолчанию.
Сохраните и закройте файл. Перезапустите Nagios, чтобы обновить настройки:
sudo service nagios reload
После настройки откройте веб-интерфейс и проверьте страницу Services; теперь она должна содержать список только что добавленных удалённых хостов.
Заключение
Настроив мониторинг хостов и некоторых сервисов, определите, какие сервисы имеют решающее значение в работе сервера, и добавьте их в список. Также можно настроить извещения; к примеру, Nagios может сообщить о том, что использование диска достигло критической отметки или что веб-сайт не работает. Это позволяет вовремя устранить подобные проблемы.
Читайте также: