@ai-solutions.ru/mikrotik-mcp-server
Allows management of MikroTik RouterOS devices, including system information, interfaces, IP addresses, firewall rules, DHCP, DNS, routing, VPN (WireGuard and IPsec), configuration backup/export, and dynamic API discovery for exploring the full RouterOS API tree.
Allows management of WireGuard VPN peers on MikroTik routers, including listing peers with traffic statistics and adding new peers.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@@ai-solutions.ru/mikrotik-mcp-servershow system info"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
@ai-solutions.ru/mikrotik-mcp-server
High-performance TypeScript MCP (Model Context Protocol) server for MikroTik RouterOS management. Connect Claude, GPT-4, or any MCP-compatible AI to your MikroTik router and manage it through natural language.
npx @ai-solutions.ru/mikrotik-mcp-server🚀 Why This Server?
Feature | This server | jeff-nasseri/mikrotik-mcp | kevinpez (nested fork) |
Language | TypeScript / Node.js | Python | Python |
Dynamic API Discovery | ✅ Browse full RouterOS API tree | ❌ | ❌ |
Structured JSON output ( | ✅ Every tool | ❌ | ❌ |
Zod output schemas | ✅ Typed & validated | ❌ | ❌ |
MCP safety annotations | ✅ | ❌ | ❌ |
WireGuard VPN management | ✅ list + add peers | ❌ | ❌ |
IPsec peer management | ✅ | ❌ | ❌ |
Configuration backup & export | ✅ binary + script export | ❌ | ❌ |
Raw command execution (escape hatch) | ✅ | ❌ | ❌ |
Pagination on all list tools | ✅ limit/offset | partial | partial |
Smart output truncation | ✅ auto-hint for large results | ❌ | ❌ |
In-memory caching | ✅ discovery cache | ❌ | ❌ |
MCP SDK version | 1.16+ (latest) | old | old |
Install via npx | ✅ zero config | ❌ pip install | ❌ pip install |
Related MCP server: MCP Server TypeScript
✨ Unique Features
1. Dynamic API Discovery (unique in ecosystem)
Browse the entire RouterOS API tree without needing to know command paths in advance. The AI can explore unknown router configurations autonomously.
→ mikrotik_discover_endpoints(path: "/ip")
Returns: address, arp, dhcp-client, dhcp-server, dns, firewall, hotspot, ipsec, ...
→ mikrotik_get_endpoint_schema(path: "/ip/firewall/filter")
Returns: available commands (print, add, remove, set, enable, disable) and parametersThis means Claude can discover and interact with any RouterOS subsystem — including packages you've installed, containers, advanced routing, hardware-specific features — without the server needing hardcoded knowledge of them.
2. Structured Content + Zod Output Schemas
Every tool returns both human-readable Markdown and machine-readable JSON via structuredContent. The JSON is validated against Zod schemas, giving you typed, predictable data structures that work with MCP clients that support structured output.
// Example: mikrotik_list_ip_addresses returns
{
content: [{ type: "text", text: "# IP Addresses\n..." }], // ← Markdown for AI
structuredContent: { // ← Typed JSON for clients
total: 5,
addresses: [{ id: "*1", address: "192.168.1.1/24", interface: "bridge", ... }]
}
}3. MCP Safety Annotations
Tools are annotated with MCP 2025 safety hints so AI clients can present appropriate warnings:
readOnlyHint: true— safe to call without side effects (list/print operations)destructiveHint: true— modifies router state (add/remove/reboot)idempotentHint: true— safe to retryopenWorldHint: true— queries live state from router
The reboot tool additionally requires confirm: true parameter as an extra safety gate.
4. VPN Management (WireGuard + IPsec)
First MikroTik MCP server with WireGuard peer management:
List all WireGuard peers with traffic stats
Add new WireGuard peers with endpoint and allowed addresses
List IPsec peers with profiles
Graceful handling when WireGuard package isn't installed
5. Raw Command Execution
mikrotik_execute_command provides a full escape hatch to the RouterOS API — execute any RouterOS command with any parameters. This enables AI to handle edge cases, new RouterOS features, or complex operations not covered by specialized tools.
6. Configuration Backup & Export
mikrotik_create_backup— binary RouterOS backup (survives factory reset)mikrotik_export_config— human-readable script export with statistics (line count, command count, size)
📋 Full Tool Reference
🖥 System (2 tools)
Tool | Description | Annotations |
| CPU, RAM, storage, uptime, version, board info | readOnly |
| Reboot device (requires | destructive |
🔌 Interfaces (3 tools)
Tool | Description |
| List all interfaces with type filter + pagination |
| Get detailed info for specific interface |
| Enable/disable, set MTU, comment |
🌐 IP Addresses (3 tools)
Tool | Description |
| List all IP addresses with interface filter + pagination |
| Add IP address to interface |
| Remove IP address by ID |
🔥 Firewall (3 tools)
Tool | Description |
| List filter rules with chain filter + pagination |
| Add filter rule with full parameter support |
| Remove rule by ID |
📡 DHCP (3 tools)
Tool | Description |
| List leases with status filter + pagination |
| Assign static IP to MAC address |
| List configured DHCP servers |
🔍 DNS (2 tools)
Tool | Description |
| List static DNS records with pagination |
| Add A/AAAA/CNAME static DNS record |
🗺 Routing (3 tools)
Tool | Description |
| List all routes with pagination |
| Add static route with distance and routing table |
| List NAT rules with chain filter + pagination |
🔐 VPN (3 tools)
Tool | Description |
| List WireGuard peers with traffic stats |
| Add WireGuard peer with endpoint |
| List IPsec peers with profiles |
💾 Backup (2 tools)
Tool | Description |
| Create binary system backup |
| Export config as text script with statistics |
⚡ Execute (1 tool)
Tool | Description |
| Execute any RouterOS API command (destructive) |
🔭 Discovery (2 tools)
Tool | Description |
| Browse RouterOS API tree at any path |
| Get available commands & params for endpoint |
Total: 27 tools + 4 MCP resources
📦 MCP Resources
Resource URI | Description |
| Live system info snapshot |
| All interface states |
| Full firewall ruleset |
| All routing table entries |
🔧 Installation & Setup
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"mikrotik": {
"command": "npx",
"args": ["-y", "@ai-solutions.ru/mikrotik-mcp-server"],
"env": {
"MIKROTIK_HOST": "192.168.88.1",
"MIKROTIK_USER": "admin",
"MIKROTIK_PASSWORD": "yourpassword",
"MIKROTIK_PORT": "8728",
"MIKROTIK_SECURE": "false"
}
}
}
}Environment Variables
Variable | Default | Description |
|
| Router IP or hostname |
|
| API username |
| (required) | API password |
|
| RouterOS API port (8729 for TLS) |
|
| Use TLS (requires port 8729) |
|
| Connection timeout in ms |
|
| Discovery cache TTL in seconds |
Enable RouterOS API
In RouterOS WebFig or terminal:
/ip service enable apiFor TLS: /ip service enable api-ssl
💬 Example Conversations
"What's the current state of my router?"
Calls
mikrotik_system_info→ Returns device name, RouterOS version, CPU load, RAM usage, uptime
"Show me all firewall rules that drop traffic"
Calls
mikrotik_list_firewall_rules(chain="forward")→ Filters by action=drop
"Add a static DNS record for myserver.local pointing to 10.0.0.50"
Calls
mikrotik_add_dns_record(name="myserver.local", address="10.0.0.50")
"List all WireGuard peers and their traffic stats"
Calls
mikrotik_list_wireguard_peers()→ Returns peers with RX/TX bytes
"What API endpoints are available under /container?"
Calls
mikrotik_discover_endpoints(path="/container")→ Browses RouterOS container API
"Export the full router config as a backup script"
Calls
mikrotik_export_config()→ Returns full RouterOS export with stats
🏗 Architecture
src/
├── index.ts # Entry point, env config
├── server.ts # MCP server + tool/resource registration
├── constants.ts # Configuration constants
├── routeros/
│ └── client.ts # RouterOS API client (node-routeros)
├── cache/
│ └── memory.ts # LRU in-memory cache
├── discovery/
│ └── service.ts # Dynamic API discovery service
├── tools/
│ ├── system.ts # System info & reboot
│ ├── interfaces.ts # Interface management
│ ├── ip-address.ts # IP address CRUD
│ ├── firewall.ts # Firewall rules
│ ├── dhcp.ts # DHCP leases & servers
│ ├── dns.ts # Static DNS records
│ ├── routing.ts # Routes & NAT
│ ├── vpn.ts # WireGuard & IPsec
│ ├── backup.ts # Backup & export
│ ├── execute.ts # Raw command execution
│ └── discovery.ts # API discovery tools
├── resources/
│ ├── system-info.ts # System resource
│ ├── interfaces.ts # Interfaces resource
│ ├── firewall.ts # Firewall resource
│ └── routing.ts # Routing resource
└── utils/
├── format.ts # Formatting, truncation, pagination
├── errors.ts # RouterOS error handling
└── logger.ts # Structured logging🔒 Security Notes
All write operations carry
destructiveHint: trueannotationReboot requires explicit
confirm: trueparameterCredentials are passed via environment variables (never in code)
TLS support via
MIKROTIK_SECURE=true+ port 8729Consider using a read-only RouterOS API user for monitoring-only setups
📜 License
MIT © AI Solutions
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Ai-Solutions-ru/mikrotik-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server