nautobot_mcp
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., "@nautobot_mcplist devices in site New York"
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.
Nautobot MCP Server
A Model Context Protocol (MCP) server for interacting with Nautobot APIs using semantic search and dynamic API requests. This server provides intelligent access to Nautobot instances and a comprehensive knowledge base of Nautobot-related repositories.
๐ Documentation
๐ Features
Core Capabilities
Dynamic API Access: Perform CRUD operations on any Nautobot API endpoint
Semantic Endpoint Discovery: Find relevant API endpoints using natural language queries
Knowledge Base Search: Access indexed content from official Nautobot repositories
Multi-Environment Support: Connect to different Nautobot instances (dev, staging, prod)
Smart Caching: Efficient ChromaDB-powered vector storage with Git-based updates
API Tools
nautobot_dynamic_api_request: Execute any HTTP method against Nautobot APIsnautobot_openapi_api_request_schema: Discover API endpoints through semantic searchnautobot_kb_semantic_search: Search through indexed Nautobot documentation and codeRepository management tools for maintaining the knowledge base
๐ Prerequisites
Python 3.11+ (< 3.12)
Access to a Nautobot instance
Git (for repository cloning and updates)
GitHub token (for accessing repositories)
Design Overview

๐ ๏ธ Installation
Option 1: Docker Installation (Recommended)
The easiest way to run the Nautobot MCP server is using Docker:
Clone the repository:
git clone <repository-url> cd nautobot_mcpConfigure environment variables:
cp .env.example .env # Edit .env with your configurationRun with Docker Compose:
# For stdio mode (default) docker compose up -d # For HTTP mode MCP_TRANSPORT=http MCP_PORT=8000 docker compose up -d
Option 2: Local Python Installation
Clone the repository:
git clone <repository-url> cd nautobot_mcpInstall dependencies:
# Using uv (recommended) uv sync # Or using pip pip install -e .Configure environment variables:
cp .env.example .env # Edit .env with your configuration
โ๏ธ Configuration
Environment Variables
Create a .env file with the following variables:
# Nautobot API Configuration
NAUTOBOT_TOKEN=your_nautobot_api_token
NAUTOBOT_ENV=local # Options: local, nonprod, prod
# Environment-specific URLs and tokens
NAUTOBOT_NONPROD_BASE_URL=https://nautobot-nonprod.example.com/
NAUTOBOT_NONPROD_TOKEN=your_nonprod_token
NAUTOBOT_PROD_BASE_URL=https://nautobot.example.com/
NAUTOBOT_PROD_TOKEN=your_prod_token
# GitHub Configuration (for knowledge base)
GITHUB_TOKEN=your_github_token
# Optional Configuration
SSL_VERIFY=False # Set to True for production
POSTHOG_API_KEY=disable # Analytics (optional)Repository Configuration
The knowledge base automatically indexes official Nautobot repositories. You can customize this by editing:
config/repositories.json- Official and community repositoriesconfig/user_repositories.json- Your custom repositories
Example repository configuration:
{
"name": "nautobot/nautobot",
"description": "Core Nautobot application",
"priority": 1,
"enabled": true,
"branch": "develop",
"file_patterns": [".py", ".md", ".txt", ".rst", ".yaml", ".yml"]
}Configuration Options Reference
Environment Variable | Default | Description |
| `` | API token for authentication |
|
| Environment selection (local/nonprod/prod) |
|
| GitHub token for repository access |
|
| MCP tool prefix |
|
| MCP server name |
|
| Server version |
|
| Logging level |
|
| Sentence transformer model |
|
| Default number of search results |
|
| PostHog analytics API key |
|
| Request timeout in seconds |
|
| SSL certificate verification |
๐ Usage
Starting the MCP Server
Docker Usage
stdio mode (for MCP clients like Claude Desktop, VS Code, etc.):
# Using docker compose
docker compose up -d
# Or using docker run
docker run -d \
--name nautobot-mcp \
--env-file .env \
-v nautobot-mcp-chroma:/app/backend/chroma_db \
-v nautobot-mcp-models:/app/backend/models \
nautobot-mcp:latest --mode stdioHTTP mode (for web-based integrations):
# Using docker compose
MCP_TRANSPORT=http MCP_PORT=8000 docker compose up -d
# Or using docker run
docker run -d \
--name nautobot-mcp \
--env-file .env \
-e MCP_TRANSPORT=http \
-e MCP_PORT=8000 \
-p 8000:8000 \
-v nautobot-mcp-chroma:/app/backend/chroma_db \
-v nautobot-mcp-models:/app/backend/models \
nautobot-mcp:latest --mode http --port 8000View logs:
# Follow logs
docker compose logs -f
# View last 100 lines
docker compose logs --tail=100Stop the server:
docker compose down
# To also remove volumes (warning: deletes ChromaDB data)
docker compose down -vLocal Python Usage
stdio mode:
python main.py
# or
python main.py --mode stdioHTTP mode:
python main.py --mode http
# or with custom port
python main.py --mode http --port 9000Legacy server files (still supported):
# stdio mode
python server.py
# HTTP mode
python server_http.pyThe server will automatically:
Initialize the ChromaDB collections
Refresh the API endpoint index
Update the knowledge base from configured repositories
Start serving MCP requests
Integration with VS Code Copilot
Add to your VS Code MCP settings to use with GitHub Copilot:
VS Code: Command Palete:
'>MCP: Open User Configuration'
Local Installation:
{
"servers": {
"nautobot_mcp": {
"type": "stdio",
"command": "uv",
"args": [
"run",
"--directory",
"/path/to/nautobot_mcp",
"python",
"main.py",
"--mode",
"stdio"
]
}
},
"inputs": []
}Docker Installation:
{
"servers": {
"nautobot_mcp": {
"type": "stdio",
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"--env-file",
"/path/to/nautobot_mcp/.env",
"-v",
"nautobot-mcp-chroma:/app/backend/chroma_db",
"-v",
"nautobot-mcp-models:/app/backend/models",
"nautobot-mcp:latest",
"--mode",
"stdio"
]
}
},
"inputs": []
}Docker Configuration Notes
Data Persistence:
ChromaDB data is stored in the
nautobot-mcp-chromavolumeSentence transformer models are cached in the
nautobot-mcp-modelsvolumeVolumes persist across container restarts and rebuilds
To reset the knowledge base, remove the volumes:
docker compose down -v
Environment Variables:
All configuration is done through the
.envfileThe
.envfile is loaded automatically when usingdocker composeFor
docker run, use--env-file .envor-e VAR=valuefor individual variables
Transport Modes:
stdio mode: For integration with MCP clients (Claude Desktop, VS Code, etc.)
HTTP mode: For web-based integrations or REST API access
Switch modes by setting
MCP_TRANSPORT=httporMCP_TRANSPORT=stdio
Resource Management:
Default limits: 2 CPU cores, 4GB RAM
Adjust in
docker compose.ymlunderdeploy.resourcesMonitor usage:
docker stats nautobot-mcp-server
Logs:
View logs:
docker compose logs -fLogs are rotated (max 10MB per file, 3 files retained)
Adjust in
docker compose.ymlunderlogging
### Example API Requests
#### Search for API Endpoints
```python
# Find endpoints related to devices
query = "get device information"
# Returns relevant endpoints like /dcim/devices/Execute API Requests
# Get all locations
method = "GET"
path = "/dcim/locations/"
params = {"limit": 100}Search Knowledge Base
# Find documentation about custom fields
query = "how to create custom fields in Nautobot"
# Returns relevant documentation and code examples๐ Project Structure
nautobot_mcp/
โโโ server.py # Main MCP server
โโโ pyproject.toml # Project configuration
โโโ .env # Environment variables
โ
โโโ config/ # Configuration files
โ โโโ repositories.json # Official repository definitions
โ โโโ user_repositories.json # User-defined repositories
โ
โโโ helpers/ # Core modules
โ โโโ nb_kb_v2.py # Enhanced knowledge base
โ โโโ endpoint_searcher_chroma.py # API endpoint search
โ โโโ content_processor.py # Document processing
โ โโโ manage_repos.py # Repository management
โ
โโโ utils/ # Utility modules
โ โโโ config.py # Configuration management
โ โโโ embedding.py # Vector embedding utilities
โ โโโ git_manager.py # Git operations
โ โโโ repo_config.py # Repository configuration
โ
โโโ examples/ # Usage examples
โ โโโ example_kb_search.py # Knowledge base search demo
โ โโโ config_demo.py # Configuration examples
โ โโโ pynautobot_kb_example/ # PyNautobot integration
โ
โโโ tests/ # Test suite
โ โโโ test_nb_kb_v2.py # Knowledge base tests
โ โโโ test_endpoint_searcher_chroma.py # API search tests
โ โโโ test_manage_repos.py # Repository management tests
โ
โโโ backend/ # Data storage
โโโ models/ # Cached embedding models๐ง Development
Running Tests
# Run all tests
pytest
# Run specific test categories
pytest -m "unit"
pytest -m "integration"
pytest -m "not slow"
# Run with coverage
pytest --cov=helpers --cov=utilsCode Quality
The project uses several tools for code quality:
# Format code
ruff format .
# Lint code
ruff check .
# Pre-commit hooks (install once)
pre-commit installAdding New Repositories
To add repositories to the knowledge base:
Add to configuration:
from helpers.manage_repos import RepositoryManager manager = RepositoryManager() manager.add_repository("owner/repo", category="custom", description="My custom repo")Initialize the repository:
manager.initialize_repositories(force=True)
๐ Examples
Basic Knowledge Base Search
from helpers.nb_kb_v2 import EnhancedNautobotKnowledge
kb = EnhancedNautobotKnowledge()
results = kb.search("custom field validation", n_results=5)
for result in results:
print(f"Repository: {result['metadata']['repository']}")
print(f"File: {result['metadata']['file_path']}")
print(f"Content: {result['document'][:200]}...")API Endpoint Discovery
from helpers.endpoint_searcher_chroma import EndpointSearcherChroma
searcher = EndpointSearcherChroma()
endpoints = searcher.search("create new device", n_results=3)
for endpoint in endpoints:
print(f"Method: {endpoint['method']}")
print(f"Path: {endpoint['path']}")
print(f"Description: {endpoint['description']}")Dynamic API Requests
import requests
from utils.config import config
# Example: Get device count
response = requests.get(
f"{config.NAUTOBOT_BASE_URL}/api/dcim/devices/",
headers={"Authorization": f"Token {config.NAUTOBOT_TOKEN}"},
params={"limit": 1},
verify=config.SSL_VERIFY
)
total_count = response.json()["count"]
print(f"Total devices: {total_count}")๐ค Contributing
Fork the repository
Create a feature branch (
git checkout -b feature/amazing-feature)Commit your changes (
git commit -m 'Add amazing feature')Push to the branch (
git push origin feature/amazing-feature)Open a Pull Request
Development Guidelines
Follow PEP 8 style guidelines
Add tests for new functionality
Update documentation for API changes
Use type hints where appropriate
Run the full test suite before submitting
๐งช Testing & Validation
Available Examples
The examples/ directory contains several demonstration scripts:
example_kb_search.py- Basic knowledge base search functionalityexample_job.py- Example Nautobot job integrationdemo_hybrid_processing.py- Demonstrates hybrid content processingexample_detailed_search_analysis.py- Advanced search analysisfetch_schema.py- OpenAPI schema fetching utilitypynautobot_kb_example/- PyNautobot integration examples
Running Tests
The project includes comprehensive tests in the tests/ directory:
# Run all tests
uv run python -m pytest tests/
# Run specific test files
uv run python tests/test_nb_kb_v2.py
uv run python tests/test_endpoint_searcher_chroma.py
uv run python tests/test_manage_repos.pyValidation
Test your configuration and server setup:
# Test configuration
uv run python -c "from utils.config import config; print('Config OK:', config.SERVER_NAME)"
# Test server initialization
uv run python -c "from server import main; print('Server imports OK')"๐ ๏ธ MCP Tools Available
API Tools
nautobot_openapi_api_request_schema: Search for API endpoints by intentnautobot_dynamic_api_request: Execute API requests with any HTTP methodrefresh_endpoint_index: Manually refresh the endpoint search index
Knowledge Base Tools
nautobot_kb_semantic_search: Semantic search over Nautobot knowledge base repositoriesnautobot_kb_list_repos: List repositories configured in Nautobot knowledge basenautobot_kb_add_repo: Add a new repository to the Nautobot knowledge basenautobot_kb_remove_repo: Remove an existing repository from the Nautobot knowledge basenautobot_kb_update_repos: Update repositories in the Nautobot knowledge basenautobot_kb_init_repos: Initialize repositories in the Nautobot knowledge basenautobot_kb_repo_status: Show nautobot knowledge base repository status including document counts and indexing status
๐ Troubleshooting
Common Issues
SSL Certificate Errors:
# Set SSL_VERIFY=False in .env for development SSL_VERIFY=FalseChromaDB Permission Issues:
# Ensure proper permissions on the backend directory chmod -R 755 backend/GitHub API Rate Limits:
# Ensure you have a valid GitHub token GITHUB_TOKEN=your_github_tokenRepository Initialization Fails:
# Force reinitialize repositories kb = EnhancedNautobotKnowledge() kb.initialize_all_repositories(force=True)
Docker-Specific Issues
Container Won't Start:
# Check logs for errors docker compose logs # Verify environment variables docker compose config # Rebuild the image docker compose build --no-cacheVolume Permission Issues:
# Check volume permissions docker compose exec nautobot-mcp ls -la /app/backend/ # If needed, recreate volumes docker compose down -v docker compose up -dPort Already in Use (HTTP mode):
# Check what's using the port lsof -i :8000 # Use a different port MCP_PORT=9000 docker compose up -dOut of Memory Errors:
# Increase memory limits in docker compose.yml # Under deploy.resources.limits.memory # Check current usage docker stats nautobot-mcp-serverChromaDB Data Not Persisting:
# Verify volumes are created docker volume ls | grep nautobot-mcp # Inspect volume docker volume inspect nautobot-mcp-chromaBuilding Behind Corporate Proxy:
# Add proxy settings to docker compose.yml build args docker compose build \ --build-arg HTTP_PROXY=http://proxy.example.com:8080 \ --build-arg HTTPS_PROXY=http://proxy.example.com:8080
Debug Mode
Enable debug logging by setting:
LOG_LEVEL=DEBUG๐ Support
๐ Documentation - Comprehensive guides and references
๐ Issue Tracker - Bug reports and feature requests
๐ฌ Discussions - Questions and community support
๐ Examples - Check the
examples/directory for usage patterns๐งช Tests - Review the test suite for implementation details
๐ Acknowledgments
Nautobot - Network automation platform
Model Context Protocol - MCP Python SDK
ChromaDB - Vector database
Sentence Transformers - Embedding models
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
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/kvncampos/nautobot_mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server