Routing Director MCP Server
OfficialIntegrates with Juniper's Routing Director platform for network routing, assurance, optimization, and intelligence, providing device management, configuration template deployment, VPN service management, network topology visualization, and KPI monitoring.
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., "@Routing Director MCP Serverlist all critical alarms"
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.
Routing Director MCP Server
An MCP (Model Context Protocol) server that integrates with Juniper's Routing Director platform, providing intelligent access to network routing, assurance, optimization, and intelligence capabilities.
Features
Flexible Authentication: Supports both basic and token-based authentication
Multiple Transport Options: HTTP and stdio transport protocols
Device management and monitoring
Configuration template deployment
VPN service management
Network topology visualization
KPI monitoring and observability
Customer and organization management
Related MCP server: auvik-mcp
Prerequisites
Python 3.10 or 3.11
Juniper Routing Director instance
Network connectivity to Routing Director API
Valid Routing Director credentials (username/password or API token)
Installation
From Source
git clone https://github.com/Juniper/routing-director-mcp-server.git
cd routing-director-mcp-server
python -m venv .venv
source .venv/bin/activate # On Windows: .venv\Scripts\activate
pip install -r requirements.txtFrom MCP Registry
TBD
Configuration
Configuration File (config.json)
Create a config.json file with the following structure:
Basic Authentication:
{
"http_url": "https://your-routing-director-host/",
"org_id": "your-organization-id",
"auth": {
"type": "basic",
"username": "your-username@example.com",
"password": "your-password"
}
}Token Authentication:
{
"http_url": "https://your-routing-director-host/",
"org_id": "your-organization-id",
"auth": {
"type": "token",
"token": "your-api-token"
}
}Note: This authentication is between the MCP server and the Routing Director instance. The MCP server will handle authentication with Routing Director on behalf of clients connecting to it.
Configuration Parameters
http_url (required): URL of your Routing Director instance
org_id (required): Your organization ID in Routing Director
auth (required): Authentication configuration
type: Either
basicortokenusername: Routing Director username (for basic auth)
password: Routing Director password (for basic auth)
token: API token (for token auth)
components (optional): Additional component configuration to filter tools and capabilities exposed by the MCP server. If the user wishes to filter the openapi spec only for certain components, then the
componentsfield can be used to provide a list of components to filter the spec.
Components can be one of the following:
ems- For alarms related info (searching, ack and unack of alarms reported on Routing Director)juniper-resiliency-interface- For device syslog info (retrieving syslog messages collected on Routing Director)device-kpi- For fetching exception events related to Juniper Resiliency Interface (JRI) collected on Routing Director(forwarding, routing and os)
Usage
Starting the Server
python RoutingDirectorMCP.py --config config.jsonCommand Line Options
python RoutingDirectorMCP.py --helpAvailable options:
-H, --host: Server host (default: 127.0.0.1)-p, --port: Server port (default: 30030)-t, --transport: Transport type:streamable-httporstdio(default: streamable-http)-c, --config: Path to configuration file (required)-v, --verbose: Enable verbose logging
Example: Start with Custom Configuration
python RoutingDirectorMCP.py \
--config config.json \
--host localhost \
--port 8000 \
--transport streamable-http \
--verboseAuthentication between the MCP Server and the MCP Host(Claude/Copilot etc)
Token Management
The server supports token-based authentication through a token manager. If a tokens file exists, authentication is automatically enabled for HTTP transports.
For stdio transport, authentication is bypassed as it's typically used in secure local environments.
Enable authentication between MCP server and MCP client.
You can use file-based token authentication for communication between an MCP client and MCP
server. To generate a token, execute the following command in your local system:
python utils/mcp/token_cli.py generate --client-id sv@juniper.net --description "Token for SV" Where,
client-id - is an ID that you use for generating the authentication token.
The following is a sample of the generated output:
Generated new token:
ID: my-client
Token: apa_CA98sH_VwEBd79aHA6O9NxbhXQN_RqaK
Description: Production API Save the generated token in a .tokens file. By default, the token is saved in the root directory of the GitHub MCP repository.
Logging
Enable detailed logging for debugging:
LOG_LEVEL=DEBUG python RoutingDirectorMCP.py --config config.json --verboseConnecting to the MCP Server
Users can use any MCP Host (like Claude, Copilot, Chatgpt, etc.) to connect to the MCP server. When configuring the MCP Host, use the same transport type, host, and port as specified when starting the MCP server.
Configure Claude
To configure Claude:
Open the Claude configuration file in a text editor.
• On a macOS machine, run the following command in the Terminal:~/Library/Application Support/Claude/claude_desktop_config.json• On a Windows machine, open command prompt and enter:%APPDATA%\Claude\claude_desktop_config.jsonAdd your MCP server configuration as shown below:
{
"mcpServers": {
"RoutingDirector": {
"command": "/Users/username/path-to-virtual-environment/.mcp_venv/bin/python",
"args": [
"/Users/username/path-to-mcp-python-script/RoutingDirectorMCP.py",
"-c",
"/Users/username/path-to-config-json/config.json",
"-t",
"stdio"
]
}
}
}
Save the file.
Restart Claude.
Verify the connection of Claude with MCP server.
Claude is connected to the MCP server if the MCP server tools are listed under + > Connectors.
Configure Copilot : To configure Copilot:
Open Virtual Studio (VS) code.
Alternatively, you can use any other Integrated Development Environment (IDE) that supports
Copilot and MCP server,Open the MCP settings file using one of the following methods:
• On a macOS, run the following command in the Terminal: Open~/Library/Application\ Support/Code/User/mcp.jsonWhere, user is your username on the macOS machine.
• On a Windows machine, open command prompt and enter:C:/Users/YourUserName/AppData/Roaming/Code/User/mcp.jsonWhere, user is your username on the Windows machine.Add the MCP server configuration to the settings file as shown below:
{
"mcpServers": {
"RoutingDirector": {
"command": "/Users/username/path-to-virtual-environment/.mcp_venv/bin/python",
"args": [
"/Users/username/path-to-mcp-python-script/RoutingDirectorMCP.py",
"-c", "/Users/username/path-to-config-json/config.json",
"-t", "stdio"
]
}
}
} Save the file.
Close and reopen VS code for the MCP configuration changes to take effect.
Verify that Copilot is connected with the MCP server.
Copilot is connected to the MCP server if you find messages indicating successful connection to the
MCP server in the Output panel of VS code.
Alternatively, you can view MCP server tools (API calls) listed in VS code Extensions.
To ensure that the MCP server has started correctly, view the MCP server logs. The logs are
generated based on the type of communication with the AI agent:
• Starting MCP server 'Juniper Routing Directory' with transport 'stdio' if stdio is used.
• INFO Starting MCP server 'Juniper Routing Directory' with transport 'http' on http://127.0.0.1:30030/mcp if
streamable-http is used.
For more details on configuring the MCP Servers in the MCP Host Apps , please refer VScode Copilot: https://code.visualstudio.com/docs/copilot/customization/mcp-servers Claude: https://code.claude.com/docs/en/mcp
Troubleshooting
Issue: "Config file path is required"
Solution: Ensure you provide the --config flag with a valid path to your configuration file.
Issue: "Mandatory key missing in MCP config file"
Solution: Verify that your config.json includes all required keys: http_url, org_id, and auth.
Issue: "Failed to authenticate"
Solution:
Verify your Routing Director credentials
Ensure the Routing Director instance is accessible at the configured http_url
Check that your username/password or API token is correct
Verify network connectivity to the Routing Director host
Issue: Connection Refused
Solution:
Verify the server is running with
--hostand--portmatching your client configurationCheck firewall rules allow traffic on the configured port
Issue: "No tokens file found. Authentication DISABLED"
Solution: For HTTP transports requiring authentication, ensure token files are properly initialized. For development/testing, this is typically acceptable.
Version
Current version: v2.8.0
Acknowledgments
This MCP server integrates with Juniper Networks' Routing Director platform, providing enterprise-grade network intelligence and optimization capabilities.
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/Juniper/routing-director-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server