Skip to main content

MCP server for managing Jenkins operations

Project description

Jenkins MCP

smithery badge MCP server for managing Jenkins operations.

Jenkins MCP server

Installation

Installing via Smithery

To install Jenkins MCP for Claude Desktop automatically via Smithery:

npx -y @smithery/cli install @kjozsa/jenkins-mcp --client claude

Installing Manually

uvx camsnetec-jenkins-mcp

Publishing to PyPI (for maintainers)

# Install build tools
pip install build twine

# Build the package
cd /path/to/jenkins-mcp
python -m build

# Upload to PyPI (requires PyPI account or API token)
twine upload dist/*

# Or using API token
twine upload -u __token__ -p pypi-YOUR_API_TOKEN dist/*

After publishing, users can use the following MCP configuration directly:

Configuration

Add the MCP server using the following JSON configuration snippet:

{
  "mcpServers": {
    "jenkins-mcp": {
      "command": "uvx",
      "args": ["camsnetec-jenkins-mcp"],
      "env": {
        "JENKINS_URL": "https://your-jenkins-server/",
        "JENKINS_USERNAME": "your-username",
        "JENKINS_PASSWORD": "your-password",
        "JENKINS_USE_API_TOKEN": "false"
      }
    }
  }
}

Transport Modes

The server supports three transport modes, controlled by the MCP_TRANSPORT environment variable:

Mode Value Description
Standard I/O stdio (default) For local CLI usage (Claude Desktop, Cursor, etc.)
SSE sse Server-Sent Events over HTTP, for cloud deployments
Streamable HTTP streamable-http Recommended for Alibaba Cloud Bailian and similar platforms

Additional environment variables for HTTP modes (sse / streamable-http):

Variable Default Description
MCP_HOST 0.0.0.0 Bind address
MCP_PORT 8000 Listen port

Deploying to Alibaba Cloud Bailian (阿里云百炼)

1. Build Docker Image

docker build -t jenkins-mcp .

2. Push to Alibaba Cloud Container Registry (ACR)

# Login to ACR
docker login --username=<your-acr-username> registry.<region>.aliyuncs.com

# Tag the image
docker tag jenkins-mcp registry.<region>.aliyuncs.com/<namespace>/jenkins-mcp:latest

# Push
docker push registry.<region>.aliyuncs.com/<namespace>/jenkins-mcp:latest

3. Deploy to Function Compute (FC)

Create a function in Alibaba Cloud Function Compute with the following settings:

  • Runtime: Custom Container
  • Image: registry.<region>.aliyuncs.com/<namespace>/jenkins-mcp:latest
  • Port: 8000
  • Environment Variables:
    JENKINS_URL=https://your-jenkins-server/
    JENKINS_USERNAME=your-username
    JENKINS_PASSWORD=your-password
    JENKINS_USE_API_TOKEN=false
    MCP_TRANSPORT=streamable-http
    MCP_PORT=8000
    

Important: For Bailian platform, recommended MCP_TRANSPORT=streamable-http with endpoint path /mcp. Alternatively use MCP_TRANSPORT=sse with endpoint path /sse.

4. Configure in Bailian MCP Management

In the Bailian console MCP management page:

  • Transport Type: Select SSE or Streamable HTTP to match your MCP_TRANSPORT setting
  • URL: Your FC function's public endpoint
    • For SSE: https://<fc-endpoint>/sse
    • For Streamable HTTP: https://<fc-endpoint>/mcp

Troubleshooting

If you encounter error 11200053 ("No active SSE connection for session"):

  • Switch to streamable-http mode — this is the recommended transport for cloud deployments as it uses stateless_http=True and avoids session affinity issues
  • Ensure MCP_TRANSPORT is set to streamable-http (recommended) or sse (not stdio)
  • Verify the FC function port matches MCP_PORT (default 8000)
  • Check that the Bailian transport type matches the server's transport mode
  • For SSE mode: enable FC "extreme speed mode" (极速模式), set instance limit to 1, and pre-provision 1 snapshot to ensure session affinity
  • For Streamable HTTP mode: no special FC configuration needed — stateless mode works with any number of instances

CSRF Crumb Handling

Jenkins implements CSRF protection using "crumbs" - tokens that must be included with POST requests. This MCP server handles CSRF crumbs in two ways:

  1. Default Mode: Automatically fetches and includes CSRF crumbs with build requests

    • Uses session cookies to maintain the web session
    • Handles all the CSRF protection behind the scenes
  2. API Token Mode: Uses Jenkins API tokens which are exempt from CSRF protection

    • Set JENKINS_USE_API_TOKEN=true
    • Set JENKINS_PASSWORD to your API token instead of password
    • Works with Jenkins 2.96+ which doesn't require crumbs for API token auth

You can generate an API token in Jenkins at: User → Configure → API Token → Add new Token

Features

  • List Jenkins jobs
  • Trigger builds with optional parameters
  • Check build status
  • CSRF crumb handling for secure API access
  • Multiple transport modes (stdio, SSE, Streamable HTTP) for flexible deployment

Development

# Install dependencies
uv pip install -r requirements.txt

# Run in dev mode with Inspector
mcp dev jenkins_mcp/server.py

# Run with SSE transport locally
MCP_TRANSPORT=sse jenkins-mcp

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

camsnetec_jenkins_mcp-3.1.2.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

camsnetec_jenkins_mcp-3.1.2-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file camsnetec_jenkins_mcp-3.1.2.tar.gz.

File metadata

  • Download URL: camsnetec_jenkins_mcp-3.1.2.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for camsnetec_jenkins_mcp-3.1.2.tar.gz
Algorithm Hash digest
SHA256 87226c8a414c3a3d1cb592e3f1043c36f4e5643a5c94ea9221af2f8b940be345
MD5 8f8fbe0c5474d2e72be65380f0ed0ce5
BLAKE2b-256 753f48480e3755f6f10c8ac1d4ee1f7e030c511c407ecd2e0c2de0ee05ac6493

See more details on using hashes here.

File details

Details for the file camsnetec_jenkins_mcp-3.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for camsnetec_jenkins_mcp-3.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 aac3b56b36620bd0b84e85e8ba9d2b32d7778c882ca488be3d79b4bbc212c3d6
MD5 53fa6bc2a1ab46a49322454eb0a569d2
BLAKE2b-256 cb2d2e4c1709e31a48b289cba4ce7de3d35f579e0b3523e057b7dfdedef6620a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page