En fouillant GitHub comme un cochon qui veut trouver des truffes, je suis tombé sur une application de monitoring intéressante.
data:image/s3,"s3://crabby-images/ecf35/ecf353849acacdcf841d77a8285e0aabeb78dd61" alt=""
Aujourd'hui on va parler de Upstat! Une application de monitoring de vos services très simple d'utilisation, avec le tutoriel qui va suivre, Upstat n'aura plus de secret pour vous!
⚡Caractéristiques
- Surveillance des status HTTP(s).
- Graphique de l'état et de la latence.
- Notifications via Discord.
- Intervalles de 60 secondes.
- Interface utilisateur et interface graphique (UI/UX) réactive et rapide.
- Pages d'état multiples.
- Mapper les pages d'état à des domaines spécifiques.
- Tableau des pings.
- Informations sur les certificats.
- PWA.
💾 L'installation
- Créez votre compose.yml dans le dossier où vous comptez installer Upstat:
sudo nano compose.yml
- Collez ça dedans en prenant soin d'adapter les ports et les volumes suivant votre configuration:
version: "3.4"
services:
db:
restart: unless-stopped
image: postgres:13-alpine
environment:
- POSTGRES_DB=upstat
- POSTGRES_PASSWORD=postgres
volumes:
- postgres_data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U postgres"]
interval: 5s
timeout: 5s
retries: 5
api:
restart: unless-stopped
image: chamanbravo/upstat-api:latest
environment:
- DB_TYPE=postgres
- POSTGRES_DSN=postgres://postgres:postgres@db:5432/upstat?sslmode=disable
- JWT_SECRET_KEY=asdfjaskljdaq123#!@810248)_+12
depends_on:
db:
condition: service_healthy
web:
restart: unless-stopped
image: chamanbravo/upstat-web:latest
ports:
- "3025:3000"
depends_on:
- api
- db
volumes:
postgres_data:
- On va déployer l'application:
docker-compose up -d
ou avec docker-compose V2:
docker compose up -d
- Rendez-vous sur l'ip:port, suivant l'IP de votre serveur local et du port choisi, 3025 par défaut:
http://ip:3025/
ou votre domaine:
https://mondomaine.com
👤 Création du compte administrateur
Lors du premier lancement de l'application, il vous sera demandé de créer un compte administrateur:
data:image/s3,"s3://crabby-images/251cc/251ccfeac9c7042f138a8501ec0def6133af60bb" alt=""
- Username => Choisissez un nom d'utilisateur.
- Email => Indiquez une adresse e-mail.
- Password => Choisissez un mot de passe fort.
Cliquez sur Create Account, vous serez redirigé vers le tableau de bord:
data:image/s3,"s3://crabby-images/a7ed0/a7ed0162ea07e8b8c49cd4cd305a75051916e1cf" alt=""
🐋 Ajouter un service en monitoring
Cliquez sur Create:
data:image/s3,"s3://crabby-images/d95c5/d95c5e05bcbfc80e867b8e707fd638ebdee3d883" alt=""
Remplissez les informations demandées:
data:image/s3,"s3://crabby-images/0af87/0af8722e566a7066d85a8d9174572db314b7eff3" alt=""
- Name => Nommez l'application, le service, la page web.
- URL => Indiquez soit le nom de domaine ou http://ip:port.
- HTTP method used to make the request => GET
- How often to ping your monitor? => Soit 1, 5, 15, 30, 60 minute(s).
Cliquez sur Submit, dans le fond de la page, pour terminer:
data:image/s3,"s3://crabby-images/afdf3/afdf35a07d8b9edde3a338dd2c9cdb60f9588408" alt=""
Ce qui donne:
data:image/s3,"s3://crabby-images/db588/db58862f81c4073bf2440c3efc89446796c95ab0" alt=""
🔔 Notifications
Pour le moment, il n'y a que Discord comme système de notification, il va falloir créer un webhook.
Rendez-vous sur votre serveur Discord et cliquez sur Paramètres du serveur:
data:image/s3,"s3://crabby-images/5c825/5c825a383a49a6f6305f4ab4b3cb5b7de0155b4a" alt=""
Ensuite cliquez sur Intégrations:
data:image/s3,"s3://crabby-images/b6343/b6343d955c5dc66e96bae8a33d6bd5fb54a4cbc5" alt=""
Cliquez sur Créer un webhook:
data:image/s3,"s3://crabby-images/cdc7a/cdc7a95aa6e040a3fdd9a912c5b6281fab61ac7e" alt=""
Discord va créer un webhook, cliquez dessus:
data:image/s3,"s3://crabby-images/76209/7620970c54543a41c30f9d78b5d370453a1cdfe7" alt=""
Configurez votre webhook:
data:image/s3,"s3://crabby-images/9a0d5/9a0d5334e072345e396480b886dd0fd575de263d" alt=""
- Nom => Nommez-le comme vous voulez.
- Salon => Choisissez dans quel salon le message doit-être envoyé.
- Facultatif, vous pouvez choisir une icône.
Copiez l'URL du webhook (gardez l'URL au chaud pour après) et terminez en cliquant sur Enregistrer les notifications:
data:image/s3,"s3://crabby-images/c1b87/c1b87990e9f1f3e789306b1bc2135424f169aea1" alt=""
Retournez dans l'application Upstat.
On va continuer sur l'exemple d'Immich, en bout de ligne, cliquez sur les ... et choisissez Configure:
data:image/s3,"s3://crabby-images/5df5c/5df5cc4bff320e5b131cd80f98a604359cf7d66e" alt=""
Dans la partie Notifications, cliquez sure Create:
data:image/s3,"s3://crabby-images/283bf/283bf84f5d2dbba8db3919b56178d092fa61291d" alt=""
Remplissez les informations demandées:
data:image/s3,"s3://crabby-images/f0f7b/f0f7bd5880c3d1c940cd2f31b6e6192354ae1b35" alt=""
- Provider => Discord, pour le moment vous n'avez pas le choix.
- Name => Nommez votre alerte.
- Webhook URL => Collez l'URL copiée précédemment.
Terminez en cliquant sur Submit.
Retournez dans la partie Notifications et cochez Discord:
data:image/s3,"s3://crabby-images/4c51f/4c51f740620f80166e5a270adeb9e101f8784b33" alt=""
Sauvez en cliquant sur Submit.
Je vais stopper le service Immich pour déclencher une alerte après 60 secondes:
data:image/s3,"s3://crabby-images/8b641/8b641afee8fed0876c68a42c113132d5282d10ed" alt=""
La notification a bien été envoyée. Je vais relancer le service:
data:image/s3,"s3://crabby-images/f6039/f60390faf99c7dba6ce992d2607f67d5630cdbf8" alt=""
Tout est en ordre, ça fonctionne bien.
🚦 Page des status
Pour créer un page de statut cliquez sur Status Pages:
data:image/s3,"s3://crabby-images/aec1b/aec1b7aa768dbf43d24e9643931803a63944b9d5" alt=""
Cliquez sur Create:
data:image/s3,"s3://crabby-images/5582c/5582c46b58a9ace2534176a2a8f48cd69fbc0f6a" alt=""
Deux petites infos à compléter:
data:image/s3,"s3://crabby-images/f8e42/f8e42475b98b004075d401faa591321bfc3f30a2" alt=""
- Company/Org/Name => Nommez cette page comme bon vous semble.
- Slug => Choisissez un slug. Peu importe le nom.
Cliquez sur Submit pour terminer.
Retournez sur le service concerné en cliquant sur Configure:
data:image/s3,"s3://crabby-images/aaf55/aaf5571c2c810a3ccb3cf5a320f393c610a03d06" alt=""
Dans la partie Status Pages, cochez la page crée précédemment, terminez en cliquant sur Submit:
data:image/s3,"s3://crabby-images/37d77/37d77c03a039d6030ed288dac003efe57e6fc745" alt=""
Pour visiter la page des status, cliquez sur Status Pages:
data:image/s3,"s3://crabby-images/e25f3/e25f36c93cd66d2a9c9b95151e11563fcdddced5" alt=""
Vous arriverez ici:
data:image/s3,"s3://crabby-images/42555/425550e7a5c7c7601fc37eb435a48d5718390b80" alt=""
Cliquez sur Visit et voici la page des status:
data:image/s3,"s3://crabby-images/9da4d/9da4d915a0c6da38b284a6fbd57ab556fa111d86" alt=""
📊 Statistiques
Vous pouvez afficher les statistiques d'un service en cliquant dessus:
data:image/s3,"s3://crabby-images/ef63f/ef63f4ce9591e43252fa80c51be1c38c011ebc68" alt=""
Ce qui donne:
data:image/s3,"s3://crabby-images/4da26/4da26344dc5c50939480acee82b996014d24100b" alt=""
Vous pourrez mettre en pause le monitoring ou revoir la configuration:
data:image/s3,"s3://crabby-images/25333/253332fe4ab666640b6804d1a41072aaeb1c8bf1" alt=""