loading…
Search for a command to run...
loading…
Provides AI agents with SSH-based tools to manage Nokia SR Linux network devices in ContainerLab environments. Enables retrieval of device information, interfac
Provides AI agents with SSH-based tools to manage Nokia SR Linux network devices in ContainerLab environments. Enables retrieval of device information, interfaces, routes, and running configurations, plus the ability to configure network interfaces through natural language commands.
A Model Context Protocol (MCP) server that exposes 6 network management tools for a Nokia SR Linux device running in ContainerLab. Designed to be used with Claude Code as the AI agent.
┌──────────────┐ MCP (stdio) ┌──────────────────┐ SSH ┌──────────────┐
│ Claude Code │ ◄──────────────────► │ sheridan-lab-jack │ ◄──────────► │ Nokia SR │
│ (AI Agent) │ │ (MCP Server) │ │ Linux │
└──────────────┘ └──────────────────┘ │ (ContainerLab)│
└──────────────┘
| Tool | Description |
|---|---|
get_device_info |
Returns hostname, software version, chassis type, uptime |
get_interfaces |
Lists all interfaces with admin/oper state and IP addresses |
get_routes |
Shows the full routing table |
get_running_config |
Retrieves running configuration (full or by section) |
get_network_instances |
Lists all VRFs/network-instances and their interfaces |
| Tool | Description |
|---|---|
configure_interface |
Sets IP address, admin state, and description on an interface |
sudo apt install sshpass)sudo bash -c "$(curl -sL https://get.containerlab.dev)"
cd sheridan-lab-jack
sudo containerlab deploy --topo topology.yml
Wait ~60 seconds for SR Linux to fully boot. Verify with:
sudo docker ps # should show clab-sheridan-lab-jack-srl running
pip install -r requirements.txt
sudo apt install sshpass -y
sshpass -p 'NokiaSrl1!' ssh -o StrictHostKeyChecking=no admin@clab-sheridan-lab-jack-srl -- "info from state /system information"
cd sheridan-lab-jack
claude
Claude Code automatically reads .mcp.json from the project directory. Once inside Claude Code, verify with:
> use get_device_info to check the device
| Variable | Default | Description |
|---|---|---|
DEVICE_HOST |
clab-sheridan-lab-jack-srl |
Hostname or IP of the SR Linux container |
DEVICE_USERNAME |
admin |
SSH username |
DEVICE_PASSWORD |
NokiaSrl1! |
SSH password |
Credentials are never hardcoded in the server code. They are read from environment variables at runtime and passed via .mcp.json.
All write tools validate inputs before execution:
ethernet-X/Y, lo0, mgmt0, system0)sudo containerlab destroy --topo topology.yml
You: get device info
Claude: [calls get_device_info] The device is a Nokia SR Linux running version...
You: show me all interfaces
Claude: [calls get_interfaces] Here are the interfaces...
You: configure ethernet-1/1 with IP 192.168.50.1/24 and description "uplink"
Claude: [calls configure_interface] Successfully configured ethernet-1/1...
You: verify the change by showing interfaces again
Claude: [calls get_interfaces] Confirmed — ethernet-1/1 now has IP 192.168.50.1/24...
MIT
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"sheridan-lab-jack": {
"command": "npx",
"args": []
}
}
}