🌐 Nornir MCP-Server
Ein FastMCP -Server, der Netzwerkautomatisierungstools bereitstellt, die von Nornir und NAPALM unterstützt werden.
Dieser Server fungiert als Brücke und stellt Nornir/NAPALM-Netzwerkoperationen als MCP-Tools (Massively Concurrent Processing) bereit, sodass sie von kompatiblen MCP-Clients (wie der FastMCP-Web-Benutzeroberfläche) aus leicht zugänglich sind.
✨ Hauptmerkmale
Nutzt Nornir für die Bestandsverwaltung und gleichzeitige Aufgabenausführung auf Netzwerkgeräten.
Verwendet NAPALM für die Interaktion von Geräten mehrerer Anbieter (Informationserfassung, Befehlsausführung).
Erstellt mit FastMCP für die nahtlose Integration mit MCP-Clients unter Verwendung verschiedener Transportmittel (SSE in dieser Konfiguration).
Containerisiert mit Docker 🐳 für einfache Einrichtung und Bereitstellung.
Verwendet
uvfür schnelles Python-Abhängigkeitsmanagement innerhalb des Containers ⚡.
Related MCP server: Cloudflare API MCP Server
🔧 Voraussetzungen
Bevor Sie beginnen, stellen Sie sicher, dass Folgendes installiert ist:
Docker Compose (normalerweise in Docker Desktop enthalten)
⚙️ Konfiguration
Bevor Sie den Server ausführen, müssen Sie Ihr Netzwerkinventar und Ihre Geräteanmeldeinformationen konfigurieren:
Navigieren Sie zum Verzeichnis
conf/im Projekt.Bearbeiten Sie : Definieren Sie Ihre Netzwerkgeräte. Geben Sie deren Verwaltungs-IP/Hostnamen, Plattform (z. B.
ios,junos,eos), Anmeldeinformationen (falls keine Standardeinstellungen verwendet werden) an und weisen Sie sie bei Bedarf Gruppen zu.Bearbeiten Sie : Definieren Sie Gerätegruppen mit gemeinsamen Eigenschaften (wie Plattform- oder Verbindungsoptionen). Die hier vorgenommenen Einstellungen können die Standardeinstellungen überschreiben.
Bearbeiten Sie : Legen Sie die Standardanmeldeinformationen (
username,password) und Verbindungsoptionen fest (z. B. NAPALMsecretzum Aktivieren von Passwörtern oderplatform).⚠️ Wichtiger Sicherheitshinweis: Die Standardkonfiguration verwendet Klartext-Anmeldeinformationen in YAML-Dateien. Dies eignet sich für Test- und Laborumgebungen. Für die Produktion sollten Sie unbedingt die integrierten Funktionen zur Geheimnisverwaltung von Nornir (z. B. Umgebungsvariablen, HashiCorp Vault-Plugin) nutzen, um die Speicherung vertraulicher Informationen direkt in Konfigurationsdateien zu vermeiden. Passen Sie
nornir_ops.pyund Ihre Konfiguration an, wenn Sie einen Geheimnisanbieter implementieren.
Überprüfen Sie : Stellen Sie sicher, dass die Inventardateipfade (
host_file,group_file,defaults_file) korrekt auf die Dateien im Verzeichnisconf/verweisen (dies sollte standardmäßig der Fall sein). Passen Sie die Runner-Optionen (num_workers) bei Bedarf an.
▶️ Ausführen des Servers
Nach der Konfiguration können Sie den Server ganz einfach mit Docker Compose ausführen:
Stellen Sie sicher, dass Sie das Verzeichnis
conf/wie oben beschrieben konfiguriert haben.Öffnen Sie ein Terminal oder eine Eingabeaufforderung im Stammverzeichnis des Projekts (dasselbe Verzeichnis wie die Dateien
Dockerfileunddocker-compose.yml).Führen Sie den folgenden Befehl aus:
docker-compose up --build -dDas Flag
--buildweist Docker Compose an, das Image beim ersten Mal oder wenn sich Projektdateien (wie.pyDateien oderpyproject.toml) geändert haben, basierend auf derDockerfilezu erstellen.Dieser Befehl startet den Nornir MCP-Server in einem Docker-Container.
Die Serverprotokolle werden in Ihrem Terminal angezeigt. Standardmäßig sollten sie über Port
8000Ihres Hostcomputers (localhost) zugänglich sein.Um den Server zu stoppen, drücken Sie
Ctrl+Cim Terminal, in demdocker-composeausgeführt wird. Um den Container anschließend zu entfernen, führen Siedocker-compose downaus.
🔌 Zum MCP-Client hinzufügen
So verwenden Sie die von diesem Server bereitgestellten Tools in einem MCP-Client (wie der offiziellen FastMCP-Web-Benutzeroberfläche oder anderen kompatiblen Clients):
Stellen Sie sicher, dass der Nornir MCP-Server ausgeführt wird (mit
docker-compose up).Öffnen Sie Ihre MCP-Clientanwendung.
Suchen Sie nach der Option zum Hinzufügen oder Verwalten von MCP-Serververbindungen.
Fügen Sie eine neue Verbindung mit den folgenden Details hinzu:
Server-URL : Da dieser Server den SSE-Transport (Server-Sent Events) verwendet und standardmäßig auf Port 8000 läuft, lautet die URL:
http://localhost:8000/sse(Wenn Ihr Docker-Host eine andere IP-Adresse hat, auf die der Client zugreifen kann, ersetzen Sie
Verbindungsname : Geben Sie ihm einen beschreibenden Namen, zum Beispiel
Nornir Lab Server.
Speichern Sie und stellen Sie eine Verbindung zum neu hinzugefügten Server her.
Der MCP-Client sollte den
Nornir_MCP-Dienst erkennen und alle verfügbaren Tools (wieget_facts,send_commandusw.) auflisten. Sie können diese Tools nun über die Client-Oberfläche verwenden! 🎉
Dify DSL-Beispiele
Nornir MCP.yml – Ein einfaches Beispiel zum Chatten mit Ihren Geräten.
Device Check.yml – Ein Beispiel zum Ausführen eines Gerätebewertungsberichts.
🛠️ Verfügbare Tools und Ressourcen
Sobald eine Verbindung über einen MCP-Client hergestellt ist, sollten normalerweise die folgenden Tools (unter dem Dienstnamen „Nornir_MCP“) verfügbar sein:
Inventar:
list_all_hosts: Listet die in Ihrem Nornir-Inventar konfigurierten Geräte auf (conf/hosts.yaml).
NAPALM Getters: (Informationen abrufen)
get_factsget_interfacesget_interfaces_ipget_interfaces_countersget_config(mitretrieve: running, startup, candidate)get_arp_tableget_mac_address_tableget_usersget_vlansget_snmp_informationget_bgp_neighbors(Verfügbarkeit hängt von der Geräteplattform und der NAPALM-Treiberunterstützung ab)
Ausführung:
send_command: Senden Sie einen einzelnen schreibgeschützten Befehl an ein Gerät und erhalten Sie die Ausgabe.
Streaming-Ressource:
sse://updates: Stellt einen einfachen Heartbeat-Ereignisstrom bereit. (Kann von Clients abonniert werden, die SSE-Ressourcen unterstützen.)
📄 Lizenz
Dieses Projekt ist unter der MIT-Lizenz lizenziert.
🙌 Beitragen
Beiträge, Probleme und Funktionswünsche sind willkommen! Bitte reichen Sie diese über das Repository des Projekts ein.