Telegraf
Introduction​
L'agent Telegraf collecte des métriques et calcule des statuts sur les serveurs qu'il supervise, et les envoie à Centreon. Le processeur OpenTelemetry de Centreon lui permet d'interpréter les données envoyées au format OpenTelemetry.
Développé par InfluxDB, l'agent Telegraf peut être installé sur des serveurs Windows ou Linux. Centreon Engine envoie la configuration des ressources supervisées à l'agent (hôtes existants, seuils...), afin que l'agent exécute des contrôles et calcule les statuts de ces ressources.
Étant basés sur Nagios, les plugins Centreon comme les plugins personnalisés sont compatibles avec l'agent. Ceci est dû au fait que l'intégration de Centreon avec Telegraf est basée sur le format natif Nagios de données d'entrée.
Limitations​
Les limitations suivantes sont dues à des contraintes côté Telegraf ou côté Centreon.
- À cause de limitations de Telegraf, la configuration des ressources connues de l'agent est mise à jour uniquement lorsque l'agent est démarré ou redémarré (typiquement, un redémarrage de l'agent est nécessaire après avoir déployé la configuration). Techniquement, c'est l'agent qui demande à Centreon de lui envoyer la configuration la plus à jour.
- Seules les métriques connues (c'est-à -dire les métriques pour les hôtes et services existant dans Centreon) sont envoyées à Centreon. Les métriques concernant des hôtes ou services inconnus sont ignorées.
- Seuls des métriques et des status sont retournés (pas d'outputs).
- Les connexions réseau sont unidirectionnelles : les données vont de l'agent au collecteur. Cela signifie qu'un hôte situé dans une DMZ devra communiquer avec un collecteur situé dans la même DMZ.
- Lorsqu'une amélioration ou une correction sont publiées, le plugin Centreon doit être redéployé sur les hôtes supervisés (il n'y a pas de mise à jour automatique).
Étape 1: Configurez Centreon​
Installez le connecteur de supervision​
- Linux
- Windows
- Sur votre serveur central, allez à la page Configuration > Gestionnaire de connecteurs de supervision.
- Installez le connecteur de supervision Linux Telegraf Agent.
- Sur votre serveur central, allez à la page Configuration > Gestionnaire de connecteurs de supervision.
- Installez le connecteur de supervision Windows Telegraf Agent.
Créez le connecteur Telegraf​
Installez le processeur Open Telemetry pour Telegraf sur votre serveur central :
- Allez à la page Configuration > Commandes > Connecteurs.
- Créez un nouveau connecteur avec les données suivantes :
Paramètre | Valeur |
---|---|
Nom du connecteur | Telegraf |
Description du connecteurn | Telegraf |
Ligne de commande | opentelemetry --processor=nagios_telegraf --extractor=attributes --host_path=resource_metrics.scope_metrics.data.data_points.attributes.host --service_path=resource_metrics.scope_metrics.data.data_points.attributes.service |
Utilisé par la commande | Entrez Telegraf-Agent et cliquez sur Sélectionner tout |
Statut du connecteur | Activé |
Configurez Engine​
- Configurez la communication entre le collecteur et l'agent :
- Certains agents peuvent se connecter au collecteur, mais le collecteur peut également se connecter à certains agents.
- Vous pouvez sélectionner plusieurs pollers à la fois dans un même formulaire de configuration afin d'éviter d'effectuer plusieurs fois la même configuration.
- Allez à la page Configuration > Collecteurs > Configurations d'agent, puis cliquez sur Ajouter une configuration collecteur/agent.
- Dans la fenêtre qui s'ouvre, sélectionnez le type d'agent souhaité. Des champs supplémentaires apparaissent.
- Dans la section Paramètres, sélectionnez le ou les collecteurs qui recevront des données en provenance de l'agent.
- Dans la section Receveur OTLP, entrez les noms des fichiers des certificats pour la partie du collecteur (engine) qui recevra des données en provenance de l'agent. La communication entre l'agent et le collecteur se fait toujours en HTTPS. Vous devez mettre les certificats dans le répertoire /etc/pki/ du collecteur. Les fichiers doivent posséder l'extension .crt (pour les certificats) ou .key (pour la clé)
- Le Fournisseur de configuration est le serveur à l'intérieur du moteur du collecteur qui enverra à l'agent sa configuration. Entrez le port et les noms des fichiers de certificat. Les certificats doivent être stockés dans le répertoire /etc/pki/ du collecteur. Vous pouvez utiliser les mêmes certificats que pour le receveur OTLP.
Si vous configurez plusieurs collecteurs en même temps, assurez-vous que tous les fichiers de certificat aient le même nom.
-
Exportez la configuration
-
Redémarrez le moteur de collecte
systemctl restart centengine
L'agent Telegraf est maintenant capable de communiquer avec Centreon. Vous pouvez mettre vos hôtes en supervision.
Étape 2 : Préparez l'hôte​
Téléchargez et installez l'agent sur l'hôte​
- Linux
- Windows
- Alma / RHEL / Oracle Linux 8
- Alma / RHEL / Oracle Linux 9
- Debian 11 & 12
dnf -y install epel-release
dnf -y config-manager --set-enabled 'powertools'
La partie qui suit est extraite de la documentation officielle de Telegraf.
cat > /etc/yum.repos.d/influxdb.repo <<'EOF'
[influxdb]
name = InfluxData Repository - Stable
baseurl = https://repos.influxdata.com/stable/$basearch/main
enabled = 1
gpgcheck = 1
gpgkey = https://repos.influxdata.com/influxdata-archive_compat.key
EOF
dnf install -y telegraf
Puis :
- Arrêtez le service Telegraf :
systemctl stop telegraf
- Éditez le fichier telegraf.service.
vi /etc/systemd/system/telegraf.service
- Remplacez :
/usr/bin/telegraf -config /etc/telegraf/telegraf.conf -config-directory /etc/telegraf/telegraf.d $TELEGRAF_OPTS
Par (remplacez les exemples par vos propres valeurs) :
/usr/bin/telegraf -config http(s)://<ip poller>:<port poller>/engine?host=<host to monitor>
- Démarrez le service Telegraf :
systemctl start telegraf
dnf -y install epel-release
dnf -y config-manager --set-enabled 'crb'
La partie qui suit est extraite de la documentation officielle de Telegraf.
cat > /etc/yum.repos.d/influxdb.repo <<'EOF'
[influxdb]
name = InfluxData Repository - Stable
baseurl = https://repos.influxdata.com/stable/$basearch/main
enabled = 1
gpgcheck = 1
gpgkey = https://repos.influxdata.com/influxdata-archive_compat.key
EOF
dnf install -y telegraf
Puis :
- Arrêtez le service Telegraf :
systemctl stop telegraf
- Éditez le fichier telegraf.service.
vi /etc/systemd/system/telegraf.service
- Remplacez :
/usr/bin/telegraf -config /etc/telegraf/telegraf.conf -config-directory /etc/telegraf/telegraf.d $TELEGRAF_OPTS
Par (remplacez les exemples par vos propres valeurs) :
/usr/bin/telegraf -config http(s)://<ip poller>:<port poller>/engine?host=<host to monitor>
- Démarrez le service Telegraf :
systemctl start telegraf
La partie qui suit est extraite de la documentation officielle de Telegraf.
wget -q https://repos.influxdata.com/influxdata-archive_compat.key -O influxdata-archive_compat.key
echo '393e8779c89ac8d958f81f942f9ad7fb82a25e133faddaf92e15b16e6ac9ce4c influxdata-archive_compat.key' | sha256sum -c && cat influxdata-archive_compat.key | gpg --dearmor | tee /etc/apt/trusted.gpg.d/influxdata-archive_compat.gpg > /dev/null
echo 'deb [signed-by=/etc/apt/trusted.gpg.d/influxdata-archive_compat.gpg] https://repos.influxdata.com/debian stable main' | sudo tee /etc/apt/sources.list.d/influxdata.list
apt-get update
apt-get -y install telegraf
Vous devez alors configurer la sortie OpenTelemetry de Telegraf. Vous devez décommenter ce paragraphe ou bien recréer un fichier de configuration avec juste les lignes suivantes :
# [[outputs.opentelemetry]]
# ## Override the default (localhost:4317) OpenTelemetry gRPC service
# ## address:port
# # service_address = "localhost:4317"
#
# ## Override the default (5s) request timeout
# # timeout = "5s"
#
# ## Optional TLS Config.
# ##
# ## Root certificates for verifying server certificates encoded in PEM format.
# # tls_ca = "/etc/telegraf/ca.pem"
# ## The public and private keypairs for the client encoded in PEM format.
# ## May contain intermediate certificates.
# # tls_cert = "/etc/telegraf/cert.pem"
# # tls_key = "/etc/telegraf/key.pem"
# ## Use TLS, but skip TLS chain and host verification.
# # insecure_skip_verify = false
# ## Send the specified TLS server name via SNI.
# # tls_server_name = "foo.example.com"
Si la communication entre Telegraf et le collecteur n'est pas chiffrée, il vous suffit de renseigner service_address avec l'adresse IP et le port du collecteur (port renseigné dans le champ otel_server dans la configuration du collecteur). Sinon, il vous faudra aussi renseigner au moins l'option tls_ca.
Maintenant, il vous faut ajouter le serveur de configuration de Telegraf fourni par le collecteur. Vous devez créer le fichier /etc/default/telegraf et y ajouter la ligne suivante:
TELEGRAF_OPTS=-config https://<ip poller>:<http_server port>/engine?host=<host_to_monitor>
Les arguments de cette commande permettront à Telegraf de savoir où aller chercher la configuration des ressources qu'il doit superviser (c'est-à -dire sur le collecteur ou sur le central suivant l'IP définie dans la commande). Le paramètre <host_to_monitor>
est le nom de l'hôte tel qu'entré dans le champ Nom de sa configuration.
Il vous reste maintenant à redémarrer Telegraf :
systemctl restart telegraf
-
Téléchargez l'agent sur tous les serveurs que vous voulez superviser.
-
Vous devez alors configurer la sortie OpenTelemetry de Telegraf. Vous devez décommenter ce paragraphe ou bien recréer un fichier de configuration avec juste les lignes suivantes :
[[outputs.opentelemetry]]
## Override the default (localhost:4317) OpenTelemetry gRPC service
## address:port
# service_address = "localhost:4317"
## Override the default (5s) request timeout
# timeout = "5s"
## Optional TLS Config.
## Root certificates for verifying server certificates encoded in PEM format.
# tls_ca = "/etc/telegraf/ca.pem"
## The public and private keypairs for the client encoded in PEM format.
## May contain intermediate certificates.
# tls_cert = "/etc/telegraf/cert.pem"
# tls_key = "/etc/telegraf/key.pem"
## Use TLS, but skip TLS chain and host verification.
# insecure_skip_verify = false
## Send the specified TLS server name via SNI.
# tls_server_name = "foo.example.com"
3. Installez l'agent sur les serveurs à l'aide de la commande suivante (remplacez les paramètres d'exemple par vos propres valeurs) :
```shell
.\telegraf.exe --service install --config <chemin du fichier de conf> --config "http://<ip_poller>:<port poller>/engine?host=<host_to_monitor>"
Les arguments de cette commande permettront à Telegraf de savoir où aller chercher la configuration des resources qu'il doit superviser (c'est-à -dire sur le collecteur ou sur le central suivant l'IP définie dans la commande). Le paramètre <host_to_monitor>
est le nom de l'hôte tel qu'entré dans le champ Nom de sa configuration.
Déployer le plugin Centreon sur l'hôte​
Le plugin Centreon exécutera les contrôles sur l'hôte.
- Linux
- Windows
Activez les dépôts Centreon et installez le plugin​
Ce dépôt permettra d'installer les plugins Centreon ainsi que les dépendances qui ne peuvent pas être satisfaites par les dépôts standards des distributions.
- Alma / RHEL / Oracle Linux 8
- Alma / RHEL / Oracle Linux 9
- Debian 11 & 12
cat >/etc/yum.repos.d/centreon-plugins.repo <<'EOF'
[centreon-plugins-stable]
name=Centreon plugins repository.
baseurl=https://packages.centreon.com/rpm-plugins/el8/stable/$basearch/
enabled=1
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-stable-noarch]
name=Centreon plugins repository.
baseurl=https://packages.centreon.com/rpm-plugins/el8/stable/noarch/
enabled=1
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-testing]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el8/testing/$basearch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-testing-noarch]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el8/testing/noarch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-unstable]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el8/unstable/$basearch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-unstable-noarch]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el8/unstable/noarch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
EOF
Installez le plugin :
dnf install -y centreon-plugin-Operatingsystems-Linux-Local.noarch
cat >/etc/yum.repos.d/centreon-plugins.repo <<'EOF'
[centreon-plugins-stable]
name=Centreon plugins repository.
baseurl=https://packages.centreon.com/rpm-plugins/el9/stable/$basearch/
enabled=1
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-stable-noarch]
name=Centreon plugins repository.
baseurl=https://packages.centreon.com/rpm-plugins/el9/stable/noarch/
enabled=1
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-testing]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el9/testing/$basearch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-testing-noarch]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el9/testing/noarch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-unstable]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el9/unstable/$basearch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
[centreon-plugins-unstable-noarch]
name=Centreon plugins repository. (UNSUPPORTED)
baseurl=https://packages.centreon.com/rpm-plugins/el9/unstable/noarch/
enabled=0
gpgcheck=1
gpgkey=https://yum-gpg.centreon.com/RPM-GPG-KEY-CES
module_hotfixes=1
EOF
Installez le plugin :
dnf install -y centreon-plugin-Operatingsystems-Linux-Local.noarch
wget -O- https://apt-key.centreon.com | gpg --dearmor | tee /etc/apt/trusted.gpg.d/centreon.gpg > /dev/null 2>&1
echo "deb https://packages.centreon.com/apt-plugins-stable/ $(lsb_release -sc) main" | tee /etc/apt/sources.list.d/centreon-plugins.list
apt-get update
Installez le plugin :
apt -y install centreon-plugin-operatingsystems-linux-local
Sur les hôtes que vous voulez superviser, téléchargez et exécutez le plugin pour Windows.
Nous vous suggérons de le déposer au même emplacement que l'agent Telegraf, par exemple C:\Program Files\InfluxData\telegraf\telegraf-1.30.3
.
Étape 3 : Mettez l'hôte en supervision​
Créez l'hôte en utilisant le bon modèle​
- Linux
- Windows
Sur le serveur central, créez l'hôte et appliquez-leur le modèle d'hôtes OS-Linux-Telegraf-Agent-custom.
Sur le serveur central, créez l'hôte et appliquez-leur le modèle d'hôtes OS-Windows-Telegraf-Agent-custom.
Redémarrez l'agent​
Pour que l'agent connaisse les services nouvellement créés et puisse les superviser, exécutez la commande suivante sur l'hôte :
- Linux
- Windows
systemctl restart telegraf
telegraf.exe --service stop
telegraf.exe --service start