Integrations
Provides containerization for the server, enabling easy setup and deployment with Docker and Docker Compose.
Mentions integration with HashiCorp Vault for secrets management as an alternative to plaintext credentials in configuration files.
Uses Python-based frameworks like Nornir and NAPALM to provide network automation tools that can interact with multi-vendor network devices.
🌐 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
uv
für schnelles Python-Abhängigkeitsmanagement innerhalb des Containers ⚡.
🔧 Voraussetzungen
Bevor Sie beginnen, stellen Sie sicher, dass Folgendes installiert ist:
- Docker
- 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
hosts.yaml
: 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
groups.yaml
: Definieren Sie Gerätegruppen mit gemeinsamen Eigenschaften (wie Plattform- oder Verbindungsoptionen). Die hier vorgenommenen Einstellungen können die Standardeinstellungen überschreiben. - Bearbeiten Sie
defaults.yaml
: Legen Sie die Standardanmeldeinformationen (username
,password
) und Verbindungsoptionen fest (z. B. NAPALMsecret
zum 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.py
und Ihre Konfiguration an, wenn Sie einen Geheimnisanbieter implementieren.
- ⚠️ 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
- Überprüfen Sie
config.yaml
: 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
Dockerfile
unddocker-compose.yml
). - Führen Sie den folgenden Befehl aus:Copy
- Das Flag
--build
weist Docker Compose an, das Image beim ersten Mal oder wenn sich Projektdateien (wie.py
Dateien oderpyproject.toml
) geändert haben, basierend auf derDockerfile
zu erstellen. - Dieser Befehl startet den Nornir MCP-Server in einem Docker-Container.
- Das Flag
- Die Serverprotokolle werden in Ihrem Terminal angezeigt. Standardmäßig sollten sie über Port
8000
Ihres Hostcomputers (localhost) zugänglich sein. - Um den Server zu stoppen, drücken Sie
Ctrl+C
im Terminal, in demdocker-compose
ausgeführt wird. Um den Container anschließend zu entfernen, führen Siedocker-compose down
aus.
🔌 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
localhost
durch diese IP, z. B.http://192.168.1.100:8000/sse
.)
- Verbindungsname : Geben Sie ihm einen beschreibenden Namen, zum Beispiel
Nornir Lab Server
.
- Server-URL : Da dieser Server den SSE-Transport (Server-Sent Events) verwendet und standardmäßig auf Port 8000 läuft, lautet die URL:
- 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_command
usw.) 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_facts
get_interfaces
get_interfaces_ip
get_interfaces_counters
get_config
(mitretrieve
: running, startup, candidate)get_arp_table
get_mac_address_table
get_users
get_vlans
get_snmp_information
get_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.
This server cannot be installed
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Ein FastMCP-Server, der Tools zur Netzwerkautomatisierung bereitstellt, indem er Nornir- und NAPALM-Operationen als MCP-Tools verfügbar macht und es Benutzern ermöglicht, Netzwerkgeräte über kompatible MCP-Clients zu verwalten und mit ihnen zu interagieren.
Related MCP Servers
- -securityAlicense-qualityThis MCP server allows you to connect MCP clients with Toolhouse's tools.Last updated -8PythonMIT License
- -securityFlicense-qualityA configurable MCP server that dynamically loads capabilities from a remote configuration to bridge MCP clients with remote APIs for executing actions, accessing resources, and utilizing prompt templates.Last updated -1,2614TypeScript
- -securityAlicense-qualityFastMCP is a comprehensive MCP server allowing secure and standardized data and functionality exposure to LLM applications, offering resources, tools, and prompt management for efficient LLM interactions.Last updated -3PythonMIT License
- AsecurityFlicenseAqualityAn MCP server that allows users to interact with YNAB data, enabling access to account balances, transactions, and the creation of new transactions through the Model Context Protocol.Last updated -101Python