docs: update sysadmin/Monitoring/Gatus

main
Федоров Дмитрий 2024-08-08 14:51:51 +00:00 committed by Dmitriy Fedorov
parent 481404b050
commit 8730ac5fba
1 changed files with 98 additions and 3 deletions

View File

@ -2,11 +2,106 @@
title: Gatus - просто мониторинг title: Gatus - просто мониторинг
description: description:
published: true published: true
date: 2024-08-08T14:48:14.334Z date: 2024-08-08T14:51:46.417Z
tags: мониторинг, gatus tags: мониторинг, gatus
editor: ckeditor editor: ckeditor
dateCreated: 2024-08-08T14:47:57.868Z dateCreated: 2024-08-08T14:47:57.868Z
--> -->
<h1 class="toc-header" id="header"> Header</h1> <p>У меня было очень много заметок про различные мониторинги. Кажется, что я уже про всё более-менее полезное что-то да писал. Оказалось, что нет. Расскажу про очередной небольшой и удобный мониторинг, который позволяет очень просто и быстро создать дашборд с зелёными и красными кнопками. Если зелёные, то всё ОК, если красные, то НЕ ОК. &nbsp;</p>
<p>Your content here</p> <p>&nbsp;</p>
<p>Речь пойдёт про Gatus (https://github.com/TwiN/gatus). С его помощью очень удобно создавать Status Page. Сразу покажу, как это будет выглядеть:</p>
<p>&nbsp;</p>
<p><a href="https://status.twin.sh">https://status.twin.sh</a></p>
<p>&nbsp;</p>
<p>И сразу же простой пример, как это настраивается. Там всё максимально просто и быстро. Мы будем проверять следующие условия:</p>
<p>&nbsp;</p>
<p>◽️Подключение к сайту <a href="https://zabbix.com">zabbix.com </a>проходит успешно, а его IP равен 188.114.99.224. Так как этот домен резолвится в разные IP, можно будет увидеть, как срабатывает проверка.</p>
<p>◽️Сайт <a href="https://github.com">github.com</a> отдаёт код 200 при подключении и содержит заголовок страницы GitHub: Lets build from here · GitHub. &nbsp;</p>
<p>◽️Сайт ya.ru отдаёт код 200 и имеет отклик менее 10 мс. На практике он будет больше, посмотрим, как срабатывает триггер. По этой проверке будет уведомление в Telegram.</p>
<p>◽️Домен <a href="https://vk.com">vk.com</a> имеет сертификат со сроком истечения не менее 48 часов и делегирование домена не менее 720 часов. &nbsp;</p>
<p>&nbsp;</p>
<p>Специально подобрал разнообразные примеры, чтобы вы оценили возможности мониторинга. Я просто открыл документацию и сходу по ней всё сделал. Всё очень просто и понятно, особо разбираться не пришлось. Создаём конфигурационный файл для этих проверок:</p>
<pre><code class="language-plaintext"># mkdir gatus &amp;&amp; cd gatus
# touch config.yaml
</code></pre>
<pre><code class="language-plaintext">alerting:
telegram:
token: "1393668911:AAHtEAKqxUH7ZpyX28R-wxKfvH1WR6-vdNw"
id: "210806260"
endpoints:
- name: Zabbix Connection
url: "https://zabbix.com"
interval: 30s
conditions:
- "[CONNECTED] == true"
- "[IP] == 188.114.99.224"
- name: Github Title
url: "https://github.com"
interval: 30s
conditions:
- "[STATUS] == 200"
- "[BODY] == pat(*&lt;title&gt;GitHub: Lets build from here · GitHub&lt;/title&gt;*)"
- name: Yandex response
url: "https://ya.ru"
interval: 30s
conditions:
- "[STATUS] == 200"
- "[RESPONSE_TIME] &lt; 10"
alerts:
- type: telegram
send-on-resolved: true
- name: VK cert &amp; domain
url: "https://vk.com"
interval: 5m
conditions:
- "[CERTIFICATE_EXPIRATION] &gt; 48h"
- "[DOMAIN_EXPIRATION] &gt; 720h"
</code></pre>
<p>Запускаем Docker контейнер и цепляем к нему этот файл:</p>
<pre><code class="language-plaintext"># docker run -p 8080:8080 -d \
--mount type=bind,source="$(pwd)"/config.yaml,target=/config/config.yaml \
--name gatus twinproduction/gatus
</code></pre>
<p>Идём по IP адресу сервера на порт 8080 и смотрим на свой мониторинг. Данные могут храниться в оперативной памяти, sqlite или postgresql базе. Если выберите последнее, то вот готовый docker-compose (https://github.com/TwiN/gatus/blob/master/.examples/docker-compose-postgres-storage/docker-compose.yml) для этого. По умолчанию данные хранятся в оперативной памяти и после перезапуска контейнера пропадают. &nbsp;</p>
<pre><code class="language-plaintext">version: "3.9"
services:
postgres:
image: postgres
volumes:
- ./data/db:/var/lib/postgresql/data
ports:
- "5432:5432"
environment:
- POSTGRES_DB=gatus
- POSTGRES_USER=username
- POSTGRES_PASSWORD=password
networks:
- web
gatus:
image: twinproduction/gatus:latest
restart: always
ports:
- "8080:8080"
environment:
- POSTGRES_USER=username
- POSTGRES_PASSWORD=password
- POSTGRES_DB=gatus
volumes:
- ./config:/config
networks:
- web
depends_on:
- postgres
networks:
web:</code></pre>
<p>Штука простая и удобная. Меня не раз просили посоветовать что-то для простого дашборда с зелёными кнопками, когда всё нормально и красными, когда нет. Вот это идеальный вариант под такую задачу.</p>
<p>Также с помощью этого мониторинга удобно сделать дашборд для мониторинга мониторингов, чтобы понимать, живы они или нет.</p>
<figure class="image"><img src="/sysadmin/img/gatus.png"></figure>
<p>&nbsp;</p>