MkDocs Plugin to Serve MCP
A proof-of-concept — feedback welcome!
mkdocs-mcp
is an experimental plugin designed to integrate an MCP server into the MkDocs workflow. Due to limitations in MkDocs, the native mkdocs serve
command cannot be overridden.
Instead, this project provides the mkdocs_mcp
script to handle the build process and launch the MCP server.
This project uses uv
for dependency management and virtual environments.
To start the MCP server:
uv run mkdocs-mcp -mt stdio
Make sure to include mcp
in your mkdocs.yml
plugin list:
plugins:
- mcp:
naming_style: src_file # "src_file"(default), "dst_url" or "title"
prefer_markdown: True # By default the source markdown is used, set to False to convert the output HTML to markdown
combine_all_pages: False # Aggregate all pages into one file
combine_by_folder: False # Aggregate each folder
If you're working with Claude Desktop and WSL, configure your claude_desktop_config.json
as follows (adjust paths as needed):
{
"mcpServers": {
"mkdocs": {
"command": "wsl.exe",
"args": [
"bash",
"-c",
"/home/urs/.cargo/bin/uv run --directory /home/urs/projects/mkdocs-mcp mkdocs-mcp -mt stdio"
]
}
}
}
For development and debugging, you can directly inspect the MCP server:
uv run mcp dev src/mkdocs_mcp/__main__.py
- This project is still in the early proof-of-concept stage.
- Contributions and feedback are highly encouraged!
Thanks for checking out mkdocs-mcp
!