Maison Tutoriel système Linux Surveillance des requêtes SQL effectuées sur Slack

Surveillance des requêtes SQL effectuées sur Slack

Jan 17, 2024 pm 07:45 PM
linux linux教程 红帽 linux系统 linux命令 certification Linux chapeau rouge Linux vidéo Linux

Surveillance des requêtes SQL effectuées sur Slack

Une simple astuce Go pour recevoir des notifications sur les requêtes lentes, les erreurs inattendues et d'autres journaux importants.

Mon bot Slack m'a interrogé sur une requête SQL de longue durée. Je devrais le réparer dès que possible.

Nous ne pouvons pas gérer ce que nous ne pouvons pas mesurer. Chaque application backend nous oblige à surveiller ses performances sur la base de données. Si une requête particulière ralentit à mesure que la quantité de données augmente, vous devez l'optimiser avant qu'elle ne devienne trop lente.

Alors que Slack est devenu au cœur de notre travail, il change également la façon dont nous surveillons nos systèmes. Même si nous disposons déjà de très bons outils de surveillance, c’est également une excellente idée de demander à un robot Slack de nous indiquer si quelque chose dans le système est en train de disparaître. Par exemple, une requête SQL prend trop de temps ou une erreur fatale se produit dans un package Go spécifique.

Dans cet article de blog, nous vous expliquerons comment configurer un système de journalisation simple prenant déjà en charge ces fonctionnalités et une bibliothèque de bases de données existante pour atteindre cet objectif.

Utilisez un enregistreur

logger est une petite bibliothèque conçue pour être utilisée par les bibliothèques et applications Go. Dans cet exemple, nous utilisons ses trois fonctionnalités importantes :

Il fournit une minuterie simple pour mesurer les performances.
Prend en charge les filtres de sortie complexes, afin que vous puissiez sélectionner les journaux des packages spécifiés. Par exemple, vous pouvez demander à l'enregistreur de générer uniquement des paquets de base de données et de générer uniquement des journaux de minuterie d'une durée supérieure à 500 ms.
Il dispose d'un hook Slack, vous permettant ainsi de filtrer et d'alimenter les journaux dans Slack.
Voyons comment utiliser une minuterie dans cet exemple, plus tard nous utiliserons également des filtres :

package main
import (
    "github.com/azer/logger"
    "time"
)
var (
  users = logger.New("users")
  database = logger.New("database")
)
func main () {
  users.Info("Hi!")
  timer := database.Timer()
  time.Sleep(time.Millisecond * 250) // sleep 250ms
  timer.End("Connected to database")
  users.Error("Failed to create a new user.", logger.Attrs{
    "e-mail": "[email protected]",
  })
  database.Info("Just a random log.")
  fmt.Println("Bye.")
}
Copier après la connexion

Aucune sortie lors de l'exécution de ce programme :

L'enregistreur est silencieux par défaut, il peut donc être utilisé dans la bibliothèque. Nous visualisons simplement le journal via une variable d'environnement : Par exemple :

$ LOG=database@timer go run example-01.go
01:08:54.997 database(250.095587ms): Connected to database.
Bye
Copier après la connexion

Dans l'exemple ci-dessus, nous avons utilisé le filtre database@timer pour afficher la sortie du journal du minuteur dans le package de base de données. Vous pouvez également essayer d'autres filtres, tels que :

LOG=* : Tous les journaux
LOG=users@error,database : tous les journaux d'erreurs des utilisateurs, tous les journaux de la base de données
LOG=*@timer,database@info : journaux du minuteur et journaux d'erreurs de tous les packages et tous les journaux de la base de données
LOG=*,users@mute : Tous les journaux sauf les utilisateurs

Envoyer les journaux à Slack

Le journal de la console est destiné à l'environnement de développement, mais nous avons besoin que le produit fournisse une interface conviviale. Grâce à slack-hook, on peut facilement l'intégrer en utilisant Slack dans l'exemple ci-dessus :

import (
  "github.com/azer/logger"
  "github.com/azer/logger-slack-hook"
)
func init () {
  logger.Hook(&slackhook.Writer{
    WebHookURL: "https://hooks.slack.com/services/...",
    Channel: "slow-queries",
    Username: "Query Person",
    Filter: func (log *logger.Log) bool {
      return log.Package == "database" && log.Level == "TIMER" && log.Elapsed >= 200
    }
  })
}
Copier après la connexion

Expliquons ce que nous avons fait dans l'exemple ci-dessus :

Ligne n°5 : définissez l'URL du webhook entrant. L'URL est liée ici.
Ligne n°6 : Sélectionnez le canal d'entrée pour le journal de flux.
Ligne n°7 : Nom d'utilisateur affiché de l'expéditeur.
Ligne n°11 : utilisez un filtre de flux pour afficher uniquement les journaux de minuterie datant de plus de 200 ms.
J'espère que cet exemple pourra vous donner une idée générale. Si vous avez d'autres questions, consultez la documentation de l'enregistreur.

Un exemple concret : CRUD

crud est une bibliothèque de style ORM pour les bases de données Go. L'une de ses fonctionnalités cachées est que le système de journalisation interne utilise un enregistreur. Cela nous permet de surveiller facilement les requêtes SQL en cours d'exécution.

Requête

Voici une requête simple qui renvoie le nom d'utilisateur reçu par e-mail :

func GetUserNameByEmail (email string) (string, error) {
  var name string
  if err := DB.Read(&name, "SELECT name FROM user WHERE email=?", email); err != nil {
    return "", err
  }
  return name, nil
}
Copier après la connexion

D'accord, celui-ci est trop court et on a l'impression qu'il manque quelque chose, ajoutons le contexte complet :

import (
  "github.com/azer/crud"
  _ "github.com/go-sql-driver/mysql"
  "os"
)
var db *crud.DB
func main () {
  var err error
  DB, err = crud.Connect("mysql", os.Getenv("DATABASE_URL"))
  if err != nil {
    panic(err)
  }
  username, err := GetUserNameByEmail("[email protected]")
  if err != nil {
    panic(err)
  }
  fmt.Println("Your username is: ", username)
}
Copier après la connexion

Nous avons donc une instance crud connectée à la base de données MySQL via la variable d'environnement DATABASE_URL. Si nous exécutons ce programme, nous verrons une ligne de sortie :

$ DATABASE_URL=root:123456@/testdb go run example.go
Your username is: azer
Copier après la connexion

Comme je l'ai déjà mentionné, la journalisation est silencieuse par défaut. Jetons un coup d'œil aux journaux internes de Crud : 

$ LOG=crud go run example.go
22:56:29.691 crud(0): SQL Query Executed: SELECT username FROM user WHERE email='[email protected]'
Your username is: azer
Copier après la connexion

C'est simple et suffisant pour que nous puissions voir comment la requête est exécutée dans notre environnement de développement.

Intégration CRUD et Slack

Logger est conçu pour la gestion de la configuration des « systèmes de journalisation internes » au niveau de l'application. Cela signifie que vous pouvez faire circuler les journaux bruts dans Slack en configurant l'enregistreur au niveau de votre application :

import (
  "github.com/azer/logger"
  "github.com/azer/logger-slack-hook"
)
func init () {
  logger.Hook(&slackhook.Writer{
    WebHookURL: "https://hooks.slack.com/services/...",
    Channel: "slow-queries",
    Username: "Query Person",
    Filter: func (log *logger.Log) bool {
      return log.Package == "mysql" && log.Level == "TIMER" && log.Elapsed >= 250
    }
  })
}
Copier après la connexion

Dans le code ci-dessus :

Nous avons importé les bibliothèques logger et logger-slack-hook.
Nous configurons les journaux de l'enregistreur pour qu'ils soient transmis à Slack. Cette configuration couvre toutes les utilisations du logger dans la base de code, y compris les dépendances tierces.
Nous avons utilisé un filtre de flux pour afficher uniquement les journaux de minuterie du package MySQL qui durent plus de 250 ms.
Cette utilisation peut être étendue au-delà du simple reporting de requêtes lentes. Personnellement, je l'utilise pour suivre les erreurs importantes dans les packages spécifiés, ainsi que pour des statistiques telles que les connexions de nouveaux utilisateurs ou les journaux de génération de paiements.

Packs mentionnés dans cet article

crud

enregistreur

enregistreur-slack-crochet

Dites-nous si vous avez des questions ou des suggestions

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Différence entre Centos et Ubuntu Différence entre Centos et Ubuntu Apr 14, 2025 pm 09:09 PM

Les principales différences entre Centos et Ubuntu sont: l'origine (Centos provient de Red Hat, pour les entreprises; Ubuntu provient de Debian, pour les particuliers), la gestion des packages (Centos utilise Yum, se concentrant sur la stabilité; Ubuntu utilise APT, pour une fréquence de mise à jour élevée), le cycle de support (CentOS fournit 10 ans de soutien, Ubuntu fournit un large soutien de LT tutoriels et documents), utilisations (Centos est biaisé vers les serveurs, Ubuntu convient aux serveurs et aux ordinateurs de bureau), d'autres différences incluent la simplicité de l'installation (Centos est mince)

Comment installer CentOS Comment installer CentOS Apr 14, 2025 pm 09:03 PM

Étapes d'installation de CentOS: Téléchargez l'image ISO et Burn Bootable Media; démarrer et sélectionner la source d'installation; sélectionnez la langue et la disposition du clavier; configurer le réseau; partitionner le disque dur; définir l'horloge système; créer l'utilisateur racine; sélectionnez le progiciel; démarrer l'installation; Redémarrez et démarrez à partir du disque dur une fois l'installation terminée.

Le choix de Centos après l'arrêt de l'entretien Le choix de Centos après l'arrêt de l'entretien Apr 14, 2025 pm 08:51 PM

CentOS a été interrompu, les alternatives comprennent: 1. Rocky Linux (meilleure compatibilité); 2. Almalinux (compatible avec CentOS); 3. Serveur Ubuntu (configuration requise); 4. Red Hat Enterprise Linux (version commerciale, licence payante); 5. Oracle Linux (compatible avec Centos et Rhel). Lors de la migration, les considérations sont: la compatibilité, la disponibilité, le soutien, le coût et le soutien communautaire.

Comment utiliser Docker Desktop Comment utiliser Docker Desktop Apr 15, 2025 am 11:45 AM

Comment utiliser Docker Desktop? Docker Desktop est un outil pour exécuter des conteneurs Docker sur les machines locales. Les étapes à utiliser incluent: 1. Installer Docker Desktop; 2. Démarrer Docker Desktop; 3. Créer une image Docker (à l'aide de DockerFile); 4. Build Docker Image (en utilisant Docker Build); 5. Exécuter Docker Container (à l'aide de Docker Run).

Explication détaillée du principe docker Explication détaillée du principe docker Apr 14, 2025 pm 11:57 PM

Docker utilise les fonctionnalités du noyau Linux pour fournir un environnement de fonctionnement d'application efficace et isolé. Son principe de travail est le suivant: 1. Le miroir est utilisé comme modèle en lecture seule, qui contient tout ce dont vous avez besoin pour exécuter l'application; 2. Le Système de fichiers Union (UnionFS) empile plusieurs systèmes de fichiers, ne stockant que les différences, l'économie d'espace et l'accélération; 3. Le démon gère les miroirs et les conteneurs, et le client les utilise pour l'interaction; 4. Les espaces de noms et les CGROUP implémentent l'isolement des conteneurs et les limitations de ressources; 5. Modes de réseau multiples prennent en charge l'interconnexion du conteneur. Ce n'est qu'en comprenant ces concepts principaux que vous pouvez mieux utiliser Docker.

Que faire après Centos arrête la maintenance Que faire après Centos arrête la maintenance Apr 14, 2025 pm 08:48 PM

Une fois CentOS arrêté, les utilisateurs peuvent prendre les mesures suivantes pour y faire face: sélectionnez une distribution compatible: comme Almalinux, Rocky Linux et CentOS Stream. Migrez vers les distributions commerciales: telles que Red Hat Enterprise Linux, Oracle Linux. Passez à Centos 9 Stream: Rolling Distribution, fournissant les dernières technologies. Sélectionnez d'autres distributions Linux: comme Ubuntu, Debian. Évaluez d'autres options telles que les conteneurs, les machines virtuelles ou les plates-formes cloud.

Que faire si l'image Docker échoue Que faire si l'image Docker échoue Apr 15, 2025 am 11:21 AM

Dépannage des étapes pour la construction d'image Docker échouée: cochez la syntaxe Dockerfile et la version de dépendance. Vérifiez si le contexte de construction contient le code source et les dépendances requis. Affichez le journal de construction pour les détails d'erreur. Utilisez l'option - cibler pour créer une phase hiérarchique pour identifier les points de défaillance. Assurez-vous d'utiliser la dernière version de Docker Engine. Créez l'image avec --t [Image-Name]: Debug Mode pour déboguer le problème. Vérifiez l'espace disque et assurez-vous qu'il est suffisant. Désactivez SELINUX pour éviter les interférences avec le processus de construction. Demandez de l'aide aux plateformes communautaires, fournissez Dockerfiles et créez des descriptions de journaux pour des suggestions plus spécifiques.

Quelle configuration de l'ordinateur est requise pour VScode Quelle configuration de l'ordinateur est requise pour VScode Apr 15, 2025 pm 09:48 PM

Vs Code Système Exigences: Système d'exploitation: Windows 10 et supérieur, MacOS 10.12 et supérieur, processeur de distribution Linux: minimum 1,6 GHz, recommandé 2,0 GHz et au-dessus de la mémoire: minimum 512 Mo, recommandée 4 Go et plus d'espace de stockage: Minimum 250 Mo, recommandée 1 Go et plus d'autres exigences: connexion du réseau stable, xorg / wayland (Linux) recommandé et recommandée et plus

See all articles