


Comment implémenter la surveillance Zabbix-API en Python (avec code)
Le contenu de cet article explique comment implémenter la surveillance Zabbix-API en Python (avec du code). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.
Les amis qui effectuent l'exploitation et la maintenance doivent savoir que la salle informatique IDC de l'entreprise dispose souvent de serveurs qui sont mis sur étagère, retirés des étagères, signalés pour réparation et mis au rebut. . S’il existe un grand nombre de serveurs, il est facile de manquer la surveillance.
Les grandes entreprises Internet intègrent des systèmes de surveillance et CMDB (système de gestion des actifs | système de base de données de gestion de configuration). Lorsqu'une nouvelle machine est lancée, les informations pertinentes seront enregistrées dans la CMDB qui reliera automatiquement les informations associées en fonction des informations contenues dans la CMDB. Module CMDB, ajouter/supprimer la surveillance. De nombreuses petites entreprises ne disposent pas de système de gestion des actifs, mais en tant que responsable de la surveillance, elles doivent savoir quelles nouvelles machines ont été lancées chaque jour et s'assurer qu'elles peuvent être ajoutées à la surveillance Zabbix.
Tout d'abord, laissez-moi vous expliquer l'idée du script :
1) Utilisez l'outil Nmap pour analyser le segment de réseau et analyser les adresses IP qui ont été utilisées.
2) Utilisez Nmap pour vérifier si le port 3389 ou 22 de l'adresse IP analysée est ouvert. Vous pouvez déterminer quelles sont des machines Windows et lesquelles sont des machines Linux.
3) Recherchez le nom d'hôte Linux via la commande ssh + hostname sous Linux.
4) Sous Windows, utilisez la commande nmblookup -A pour connaître le nom d'hôte Windows.
5) Utilisez un script Python pour lire le fichier de résultats de l'analyse et écrivez le nom d'hôte dans la liste.
6) Utilisez l'API python Zabbix pour appeler le nom d'hôte surveillé et l'écrire dans la liste.
7) Prenez l'intersection des deux listes et utilisez une boucle for pour déterminer quels noms d'hôtes ne sont pas surveillés.
8) Envoyer un email pour prévenir la personne en charge du suivi.
Ci-dessous, je partagerai le script Python que j'ai écrit. Scan_machine.sh est le script que j'ai appelé en utilisant Shell pour écrire sur l'analyse Nmap. scan_hostname.log est le résultat de l'analyse Nmap, et le contenu à l'intérieur est l'hôte IP. . nom.
#!/usr/bin/env python#create by:sfzhang 20140820#coding=utf-8import os,sysimport jsonimport urllib2import datetime,timefrom urllib2 import URLError nmap_cmd = "/shell/machine/scan_machine.sh"def runCmd(command): global mail_cmd mail_cmd = '''mail -s "Report on not monitor Hosts of Zabbix" shifeng_zhang88 < /shell/machine/result/result.txt''' return os.system(command)runCmd(nmap_cmd)def nmap_host(): hostiplst = [] hostnamelst = [] f = file('/shell/machine/result/scan_hostname.log') for line in f.readlines(): hostip = line.split()[0] hostname = line.split()[1] hostiplst.append(hostip) hostnamelst.append(hostname) hostnamelst.sort() #print hostiplst return hostnamelst f.close()def zabbix_host(): zabbixhostlst= [] #based url and required header url = "http://192.168.161.128/api_jsonrpc.php" header = {"Content-Type": "application/json"} #request json data = json.dumps( { "jsonrpc": "2.0", "method": "host.get", "params":{ "output":["hostid","name"], "filter":{"host":""} }, #auth id "auth":"Zabbix Auth ID", "id": 1, }) #create request object request = urllib2.Request(url,data) for key in header: request.add_header(key,header[key]) #get host list try: result = urllib2.urlopen(request) except URLError as e: print "The server could not fulfill the request.",e.reason else: reponse = json.loads(result.read()) result.close() #print "Number of Hosts:",len(reponse['result']) for host in reponse['result']: #print "Host ID:",host['hostid'],"Host Name:",host['name'] zbxhosts=host['name'] zabbixhostlst.append(zbxhosts) zabbixhostlst.sort() return zabbixhostlst def main(): nmaphostlst = nmap_host() zbxhostlst = zabbix_host() diff = list(set(nmaphostlst) ^ set(zbxhostlst)) content = "\n" nomonitorlst = [] if len(diff) != 0: for host in diff: if host in nmaphostlst: nomonitorlst.append(host) else: sys.exit() #print zbxhostlst string = '\n'.join(nomonitorlst) f = file('/shell/machine/result/result.txt','w') f.write(string) f.flush() f.close() runCmd(mail_cmd)if __name__ == "__main__": main()
Ajoutez le script à crontab et chaque hôte recevra des informations sur les hôtes qui n'ont pas été surveillés.
Résumé :
1) Pour les informations relatives à l'API Zabbix, veuillez vérifier les détails officiels.
2) Grâce à ce script, vous pouvez savoir quels hôtes n'ont pas été surveillés. J'espère que cela sera utile à tout le monde.
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

AI Hentai Generator
Générez AI Hentai gratuitement.

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)

PHP et Python ont chacun leurs propres avantages et choisissent en fonction des exigences du projet. 1.Php convient au développement Web, en particulier pour le développement rapide et la maintenance des sites Web. 2. Python convient à la science des données, à l'apprentissage automatique et à l'intelligence artificielle, avec syntaxe concise et adaptée aux débutants.

Python excelle dans les jeux et le développement de l'interface graphique. 1) Le développement de jeux utilise Pygame, fournissant des fonctions de dessin, audio et d'autres fonctions, qui conviennent à la création de jeux 2D. 2) Le développement de l'interface graphique peut choisir Tkinter ou Pyqt. Tkinter est simple et facile à utiliser, PYQT a des fonctions riches et convient au développement professionnel.

La fonction ReadDir dans le système Debian est un appel système utilisé pour lire le contenu des répertoires et est souvent utilisé dans la programmation C. Cet article expliquera comment intégrer ReadDir avec d'autres outils pour améliorer sa fonctionnalité. Méthode 1: combinant d'abord le programme de langue C et le pipeline, écrivez un programme C pour appeler la fonction readdir et sortir le résultat: # include # include # include # includeIntmain (intargc, char * argv []) {dir * dir; structDirent * entrée; if (argc! = 2) {

Pour maximiser l'efficacité de l'apprentissage de Python dans un temps limité, vous pouvez utiliser les modules DateTime, Time et Schedule de Python. 1. Le module DateTime est utilisé pour enregistrer et planifier le temps d'apprentissage. 2. Le module de temps aide à définir l'étude et le temps de repos. 3. Le module de planification organise automatiquement des tâches d'apprentissage hebdomadaires.

Cet article vous guidera sur la façon de mettre à jour votre certificat NGINXSSL sur votre système Debian. Étape 1: Installez d'abord CERTBOT, assurez-vous que votre système a des packages CERTBOT et Python3-CERTBOT-NGINX installés. Si ce n'est pas installé, veuillez exécuter la commande suivante: Sudoapt-getUpDaSuDoapt-GetInstallCertBotpyThon3-Certerbot-Nginx Étape 2: Obtenez et configurez le certificat Utilisez la commande Certbot pour obtenir le certificat LETSCRYPT et configure

La configuration d'un serveur HTTPS sur un système Debian implique plusieurs étapes, notamment l'installation du logiciel nécessaire, la génération d'un certificat SSL et la configuration d'un serveur Web (tel qu'Apache ou Nginx) pour utiliser un certificat SSL. Voici un guide de base, en supposant que vous utilisez un serveur Apacheweb. 1. Installez d'abord le logiciel nécessaire, assurez-vous que votre système est à jour et installez Apache et OpenSSL: SudoaptupDaSuDoaptupgradeSudoaptinsta

Développer un plugin Gitlab sur Debian nécessite des étapes et des connaissances spécifiques. Voici un guide de base pour vous aider à démarrer avec ce processus. Installation de GitLab Tout d'abord, vous devez installer GitLab sur votre système Debian. Vous pouvez vous référer au manuel d'installation officiel de Gitlab. Obtenez un jeton d'accès API avant d'effectuer l'intégration de l'API, vous devez d'abord obtenir le jeton d'accès API de GitLab. Ouvrez le tableau de bord GitLab, recherchez l'option "AccessTokens" dans les paramètres utilisateur et générez un nouveau jeton d'accès. Sera généré

Apache est le héros derrière Internet. Ce n'est pas seulement un serveur Web, mais aussi une plate-forme puissante qui prend en charge un trafic énorme et fournit un contenu dynamique. Il offre une flexibilité extrêmement élevée grâce à une conception modulaire, permettant l'expansion de diverses fonctions au besoin. Cependant, la modularité présente également des défis de configuration et de performance qui nécessitent une gestion minutieuse. Apache convient aux scénarios de serveur qui nécessitent des besoins complexes hautement personnalisables.
