add blog post monitoring server

This commit is contained in:
Artur Akmalov
2023-08-01 20:21:12 +05:00
parent 37afac460b
commit 09c92d5f1b
7 changed files with 179 additions and 0 deletions

Binary file not shown.

After

Width:  |  Height:  |  Size: 114 KiB

View File

@@ -0,0 +1,179 @@
---
slug: monitoring-web-hosts
title: Monitoring web hosts
description: monitoring web ssl certificate expried uptime kuma grafana prometheus docker
image: ./monitoring-web-hosts-logo.png
tags: [monitoring, grafana, ssl, telegram, prometheus, docker]
date: 2023-07-13T10:42
---
self-hosted сервер мониторинга доступности хостов, времени действия SSL сертификатов с оповещениями в telegram
[![Monitoring web hosts](./monitoring-web-hosts-logo.png)](/blog/monitoring-web-hosts)
<!--truncate-->
## Uptime-kuma
Если вам нужен самый простой и удобный инструмент мониторинга хостов, который можно поднять у себя на сервере проще воспользоваться сервисом `Uptime-Kuma``
[Uptime-Kuma](https://github.com/louislam/uptime-kuma)
![Uptime-Kuma](./uptime-kuma.jpg)
Главные фишки:
* Мониторинг HTTP(s) / TCP / HTTP(s) Keyword / HTTP(s) Json Query / Ping / DNS
* Лекго и просто развернуть в docker-compose
* Удобный и понятный графический интерфейс
* Оповещения в Telegram, Discord, Slack, Email (SMTP) и т.д.
* Информация о сертификате (SSL Certificate info)
* Поддержка Proxy и 2FA
При обнаружении проблем с доступностью, Uptime-Kuma быстро уведомляет пользователя различными способами, включая такие популярные платформы, как Telegram, Discord и Slack.
Аналитические функции, такие как графики и статистика, предоставляют полезные данные для понимания причин проблем с доступностью, помогая пользователям своевременно реагировать и улучшать свои сервисы.
В целом, Uptime-Kuma - это незаменимый инструмент для тех, кто хочет быть уверенным в непрерывной работе и доступности своих веб-сервисов.
## Сервер мониторинга
Если уже используется стэк для мониторинга Promeheus + Grafana можно воспользваться blackbox exporter и сделать удобный Dashboard для себя. Об этом сейчас и буду писать подробнее
**Простой пример мониторинга хостов и истечения срока действия SSL-сертификата**
[![Grafana ssl certificate expires](./grafana-ssl-certificate-expires.png)](./grafana-ssl-certificate-expires.png)
Используется следующие сервисы:
- Prometheus (сбор и база данных)
- Grafana (отображение данных)
- Blackbox (мониторинг http)
- Alertmanager (уведомления)
### Установка
Сам проект на [Github monitoring hosts](https://github.com/akmalovaa/monitoring-hosts-cert/tree/main)
используется docker-compose 🐳
```bash
git clone https://github.com/akmalovaa/monitoring-hosts-cert.git
cd monitoring-hosts-cert
```
- Изменить конечные хосты `/prometheus/prometheus.yml`
- Настройка для отправки сообщений в телеграм `/alertmanager/config.yml`
- Добавить права на директорию для графаны:
``` bash
chmod -R 777 data/grafana/
```
Запустить сервисы
```bash
docker-compose up -d
```
Проверить сервисы
```bash
docker-compose ps
```
Telegram уведомления:
![telegram alertmanager](./telegram-alertmanager.png)
---
### Дополнительные материалы
* Grafana labs - [Dashboard](https://grafana.com/grafana/dashboards/13230-certificate-monitor/)
* Grafana blog - [Post SSL alerting](https://grafana.com/blog/2020/11/25/how-we-eliminated-service-outages-from-certificate-expired-by-setting-up-alerts-with-grafana-and-prometheus/)
* Github Prometheus, Grafana, blackbox, alertmanager + caddy - [docker-compose example](https://github.com/stefanprodan/dockprom/tree/master)
#### Настройки Alertmanager telegram
##### Bot token
Создайте бота и получите ключ API бота в канале [BotFather](https://t.me/BotFather)
##### Получить Chat ID telegram
Напишите пару тестовых сообщений созданному только что боту, затем выполните запрос
```bash
curl https://api.telegram.org/bot<TOKEN>/getUpdates | jq
```
#### docker-compose
```
version: "3.7"
services:
prometheus:
container_name: prometheus
image: prom/prometheus:v2.46.0
command:
- '--config.file=/etc/prometheus/prometheus.yml'
- '--storage.tsdb.path=/prometheus'
- '--web.console.libraries=/etc/prometheus/console_libraries'
- '--web.console.templates=/etc/prometheus/consoles'
- '--storage.tsdb.retention.time=30d'
- '--web.enable-lifecycle'
user: root
ports:
- 9090:9090
volumes:
- ./prometheus:/etc/prometheus/
- ./data/prometheus:/prometheus/
restart: unless-stopped
environment:
- TZ="Asia/Yekaterinburg"
blackbox:
container_name: blackbox
image: prom/blackbox-exporter:v0.24.0
command:
- '--config.file=/config/blackbox.yml'
ports:
- 9115:9115
restart: unless-stopped
volumes:
- ./blackbox:/config
alertmanager:
container_name: alertmanager
image: prom/alertmanager:v0.25.0
command:
- '--config.file=/etc/alertmanager/config.yml'
- '--storage.path=/alertmanager'
ports:
- 9093:9093
volumes:
- ./alertmanager:/etc/alertmanager/
restart: unless-stopped
grafana:
container_name: grafana
image: grafana/grafana:10.0.3-ubuntu
depends_on:
- prometheus
ports:
- 3000:3000
volumes:
- ./data/grafana:/var/lib/grafana
- ./grafana/dashboards:/etc/grafana/provisioning/dashboards
- ./grafana/datasources:/etc/grafana/provisioning/datasources
restart: unless-stopped
environment:
- GF_SECURITY_ADMIN_USER=${ADMIN_USER:-admin}
- GF_SECURITY_ADMIN_PASSWORD=${ADMIN_PASSWORD:-admin}
- GF_USERS_ALLOW_SIGN_UP=false
- TZ="Asia/Yekaterinburg"
```

Binary file not shown.

After

Width:  |  Height:  |  Size: 135 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 107 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 112 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 139 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 32 KiB