Premiers pas avec Prometheus et Grafana en Java
La surveillance est un aspect crucial de la gestion des performances des applications. À mesure que les applications évoluent, il devient impératif de garantir leur bon fonctionnement et le suivi continu de l’état du système. Dans les microservices, les systèmes distribués et les applications cloud natives, les outils de surveillance ne sont pas seulement un module complémentaire mais un élément essentiel de votre infrastructure.
Deux des outils les plus populaires pour surveiller les systèmes modernes sont Prometheus et Grafana. Ces outils sont souvent utilisés pour collecter, stocker et visualiser des métriques, aidant ainsi les développeurs et les équipes opérationnelles à détecter les problèmes, à analyser les performances et à assurer le fonctionnement efficace des systèmes.
Pourquoi avons-nous besoin d’une surveillance ?
La surveillance est essentielle pour identifier les problèmes avant qu'ils n'affectent les utilisateurs. Que vous travailliez avec un backend basé sur Java, un environnement de microservices complexe ou tout autre système, la surveillance continue fournit des informations sur :
Performances des applications :
Suivez les indicateurs de performances clés tels que les temps de réponse, les demandes et les taux d'erreur.État du système :
Surveillez l'état du serveur, l'utilisation du processeur, l'utilisation de la mémoire et l'espace disque pour garantir un fonctionnement optimal de l'infrastructure.Alertes :
Configurez des seuils et des alertes pour les mesures critiques qui vous avertissent en cas de problème.Planification des capacités :
La collecte et l'analyse des données historiques peuvent vous aider à planifier la mise à l'échelle de votre application.
Prometheus et Grafana proposent des solutions robustes pour surveiller, visualiser et analyser les données de vos systèmes et applications.
Présentation de Grafana et Prométhée
Prométhée
Prometheus est une boîte à outils open source de surveillance et d'alerte conçue pour la fiabilité et l'évolutivité. Il se concentre sur la collecte de données de séries chronologiques et prend en charge la collecte de données multidimensionnelles, permettant des requêtes et des analyses puissantes. Prometheus collecte les métriques des cibles via des points de terminaison HTTP et les stocke dans une base de données de séries chronologiques. Ces métriques peuvent ensuite être interrogées à l'aide du langage de requête de Prometheus, PromQL.
Grafana
Grafana est une plateforme open source de surveillance et d'observabilité. Il permet aux utilisateurs de visualiser des données de séries chronologiques provenant de plusieurs sources, dont Prometheus. La capacité de Grafana à créer des tableaux de bord, à configurer des alertes et à s'intégrer à un large éventail de sources de données en fait l'un des outils les plus populaires pour visualiser des métriques.
Ensemble, Prometheus collecte les métriques, tandis que Grafana les affiche de manière interactive et visuellement attrayante.
Exécuter Prometheus dans Docker
Exécuter Prometheus et Grafana dans Docker est un moyen simple et efficace de mettre en place rapidement un environnement de surveillance. Commençons par exécuter Prometheus dans Docker.
Étape 1 : Exécuter Prometheus dans Docker
Vous pouvez exécuter Prometheus en tant que conteneur à l'aide de la commande suivante :
docker run --name prometheus -d -p 127.0.0.1:9090:9090 prom/prometheus
Cette commande :
- Démarrez un conteneur Prometheus.
- Mappez le port local 9090 au port du conteneur 9090.
- Utilisez l'image officielle Prometheus Docker de Docker Hub. Vous pouvez vérifier que Prometheus est en cours d'exécution en ouvrant votre navigateur et en accédant à http://localhost:9090/.
Étape 2 : Configuration de Prometheus
Vous devez ajuster le fichier de configuration Prometheus si vous devez configurer Prometheus pour récupérer les métriques de points de terminaison spécifiques (par exemple, une application Java). En le montant dans le conteneur, vous pouvez exécuter Prometheus avec un fichier prometheus.yml personnalisé. Voici un exemple :
docker run \ -p 9090:9090 \ -v /prometheus.yml:/etc/prometheus/prometheus.yml \ prom/prometheus
Cela monte votre fichier prometheus.yml local dans le conteneur. Après avoir démarré Prometheus, vous pouvez accéder à http://localhost:9090/ pour accéder au tableau de bord Prometheus.
Exécuter Grafana dans Docker
Maintenant que Prometheus ajoute Grafana pour visualiser les données, il est temps.
Étape 3 : Exécuter Grafana dans Docker
Grafana est simple à déployer via Docker. Exécutez la commande suivante pour démarrer le conteneur Grafana :
Exécuter Grafana dans Docker
docker run -d -p 3000:3000 grafana/grafana-enterprise
Une fois Grafana exécuté, vous pouvez accéder à l'interface utilisateur Web à l'adresse http://localhost:3000/login. Les identifiants de connexion par défaut sont :
- Nom d'utilisateur : administrateur
- Mot de passe : administrateur
Étape 4 : Connecter Prometheus et Grafana
Maintenant que Prometheus et Grafana fonctionnent, l’étape suivante consiste à les connecter. Grafana doit savoir d'où obtenir les métriques. Voici comment ajouter Prometheus comme source de données dans Grafana :
- Connectez-vous à Grafana.
- cliquez sur l'icône engrenage dans la barre latérale gauche pour ouvrir le menu Configuration.
- Sélectionnez Sources de données.
- Cliquez sur Ajouter une source de données.
- Choisissez Prometheus comme type de source de données.
- Dans la section HTTP, définissez l'URL de votre instance Prometheus (par exemple, http://172.0.0.1:9090).
- Cliquez sur Enregistrer et tester pour vous assurer que Grafana peut se connecter avec succès à Prometheus.
Création d'un exemple de projet Java
Créons un projet simple basé sur Java qui expose les métriques à Prometheus. Nous utiliserons Micrometer, une façade de collection de métriques pour les applications basées sur JVM, qui s'intègre facilement à Prometheus.
Étape 5 : Créer une application Java
Ajoutez les dépendances nécessaires à votre fichier pom.xml :
Connecter tout.
docker run --name prometheus -d -p 127.0.0.1:9090:9090 prom/prometheus
Ensuite, dans votre application Java, exposez un point de terminaison que Prometheus peut gratter. Par exemple :
docker run \ -p 9090:9090 \ -v /prometheus.yml:/etc/prometheus/prometheus.yml \ prom/prometheus
Cette configuration crée un point de terminaison/métrique que Prometheus peut récupérer. Il expose les métriques collectées par Micrometer et est disponible au format Prometheus.
Étape 6 : Exposer les métriques à Prometheus
Maintenant que l'application Java collecte des métriques, nous devons dire à Prometheus de supprimer le point de terminaison /metrics de votre application. Mettez à jour votre fichier de configuration prometheus.yml pour inclure la cible :
docker run -d -p 3000:3000 grafana/grafana-enterprise
Remplacez par l'adresse IP ou localhost si vous utilisez la même machine. Prometheus va maintenant collecter les métriques de votre application Java.
Tout connecter
À ce stade, vous avez :
- Prometheus récupère les métriques de votre application Java.
- Grafana est configuré comme outil de visualisation.
Étape 7 : Création de tableaux de bord dans Grafana
Pour visualiser les données dans Grafana :
- Allez dans l'onglet Tableau de bord dans Grafana.
- Cliquez sur Nouveau tableau de bord.
- Ajoutez un Panneau et sélectionnez Prometheus comme source de données.
- Écrivez une requête PromQL pour récupérer les métriques, par exemple, http_requests_total.
Vous pouvez désormais créer un tableau de bord avec différents panneaux affichant des mesures telles que le nombre de demandes, les temps de réponse et les taux d'erreur.
La surveillance est cruciale pour maintenir une haute disponibilité et des performances élevées. Avec des outils comme Prometheus et Grafana, vous pouvez facilement mettre en place une solution de surveillance efficace pour vos applications Java.
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds











Dépannage et solutions au logiciel de sécurité de l'entreprise qui fait que certaines applications ne fonctionnent pas correctement. De nombreuses entreprises déploieront des logiciels de sécurité afin d'assurer la sécurité des réseaux internes. ...

Solutions pour convertir les noms en nombres pour implémenter le tri dans de nombreux scénarios d'applications, les utilisateurs peuvent avoir besoin de trier en groupe, en particulier en un ...

Le traitement de la cartographie des champs dans l'amarrage du système rencontre souvent un problème difficile lors de l'exécution d'amarrage du système: comment cartographier efficacement les champs d'interface du système a ...

Commencez le printemps à l'aide de la version IntelliJideaultimate ...

Lorsque vous utilisez MyBatis-Plus ou d'autres cadres ORM pour les opérations de base de données, il est souvent nécessaire de construire des conditions de requête en fonction du nom d'attribut de la classe d'entité. Si vous manuellement à chaque fois ...

Conversion des objets et des tableaux Java: Discussion approfondie des risques et des méthodes correctes de la conversion de type de distribution De nombreux débutants Java rencontreront la conversion d'un objet en un tableau ...

Comment la solution de mise en cache Redis réalise-t-elle les exigences de la liste de classement des produits? Pendant le processus de développement, nous devons souvent faire face aux exigences des classements, comme l'affichage d'un ...

Explication détaillée de la conception des tables SKU et SPU sur les plates-formes de commerce électronique Cet article discutera des problèmes de conception de la base de données de SKU et SPU dans les plateformes de commerce électronique, en particulier comment gérer les ventes définies par l'utilisateur ...
