github-mcp-server-local

shesadri/github-mcp-server-local

3.2

If you are the rightful owner of github-mcp-server-local and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

The GitHub MCP Server is a Model Context Protocol server that integrates with GitHub APIs for advanced automation and interaction.

Tools
6
Resources
0
Prompts
0

GitHub MCP Server - Local Docker Setup

This repository provides an easy way to run the GitHub MCP Server locally using Docker Compose with HTTP access on port 3000.

What is GitHub MCP Server?

The GitHub MCP Server is a Model Context Protocol (MCP) server that provides seamless integration with GitHub APIs, enabling advanced automation and interaction capabilities for developers and tools.

Features

  • Easy Setup: Just run docker-compose up to start the server
  • HTTP Access: Access the MCP server via HTTP on port 3000
  • Configurable: Support for all GitHub MCP Server configuration options
  • Auto-restart: Containers automatically restart on failure

Quick Start

Prerequisites

Setup

  1. Clone this repository:

    git clone https://github.com/shesadri/github-mcp-server-local.git
    cd github-mcp-server-local
    
  2. Create environment file:

    cp .env.example .env
    
  3. Configure your GitHub token: Edit .env file and replace your_github_token_here with your actual GitHub Personal Access Token.

  4. Start the server:

    docker-compose up -d
    
  5. Access the server: The server will be available at http://localhost:3000

Configuration

Environment Variables

VariableDescriptionDefault
GITHUB_PERSONAL_ACCESS_TOKENYour GitHub Personal Access TokenRequired
GITHUB_TOOLSETSComma-separated list of toolsets to enableall
GITHUB_DYNAMIC_TOOLSETSEnable dynamic toolset discovery (0 or 1)0
PORTHTTP server port3000

Available Toolsets

  • repos - Repository-related tools (file operations, branches, commits)
  • issues - Issue-related tools (create, read, update, comment)
  • users - Anything relating to GitHub Users
  • pull_requests - Pull request operations (create, merge, review)
  • code_security - Code scanning alerts and security features
  • experiments - Experimental features (not considered stable)

To enable specific toolsets, set GITHUB_TOOLSETS=repos,issues,pull_requests in your .env file.

Usage

Check Server Status

curl http://localhost:3000/health

Make MCP Requests

The server accepts MCP protocol requests via HTTP POST:

curl -X POST http://localhost:3000/mcp \
  -H "Content-Type: application/json" \
  -d '{
    "jsonrpc": "2.0",
    "id": 1,
    "method": "tools/list",
    "params": {}
  }'

Docker Commands

Start services

docker-compose up -d

Stop services

docker-compose down

View logs

docker-compose logs -f

Rebuild and restart

docker-compose down
docker-compose build --no-cache
docker-compose up -d

Troubleshooting

Check if containers are running

docker-compose ps

View container logs

docker-compose logs github-mcp-server
docker-compose logs mcp-http-proxy

Reset everything

docker-compose down -v
docker-compose up -d

Security Notes

  • Keep your GitHub Personal Access Token secure
  • Only grant the minimum permissions necessary for your use case
  • Consider using GitHub App tokens for production deployments
  • The server runs on localhost by default - configure firewall rules appropriately

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the original GitHub MCP Server for license details.

Related Projects