MCP HubMCP Hub
Volver a habilidades

containerize-mcp-server

pjt222
Actualizado 2 days ago
6 vistas
17
2
17
Ver en GitHub
Metaaimcpdesign

Acerca de

Esta habilidad contenedoriza servidores MCP basados en R utilizando Docker, permitiendo su despliegue sin instalaciones locales de R. Maneja la integración de mcptools, exposición de puertos y configuración de transporte (stdio/HTTP) para entornos reproducibles. Úsala para ejecutar servidores MCP junto con otros servicios contenedorizados o distribuirlos a otros desarrolladores.

Instalación rápida

Claude Code

Recomendado
Principal
npx skills add pjt222/agent-almanac -a claude-code
Comando PluginAlternativo
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativo
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/containerize-mcp-server

Copia y pega este comando en Claude Code para instalar esta habilidad

Documentación

容 MCP 伺

以 Docker 包 R MCP 伺為可移部。

用時

  • 部 R MCP 伺而無本 R 裝
  • 建可復之 MCP 伺境
  • 與他容服並行 MCP 伺
  • 分 MCP 伺於他開者

  • :R MCP 伺之實(mcptools 基或自)
  • :Docker 已裝行
  • 可選:伺所需他 R 包
  • 可選:傳之模(stdio 或 HTTP)

第一步:建 Dockerfile 為 MCP 伺

FROM rocker/r-ver:4.5.0

# Install system dependencies
RUN apt-get update && apt-get install -y \
    libcurl4-openssl-dev \
    libssl-dev \
    libxml2-dev \
    libgit2-dev \
    libssh2-1-dev \
    git \
    curl \
    && rm -rf /var/lib/apt/lists/*

# Install R packages
RUN R -e "install.packages(c( \
    'remotes', \
    'ellmer' \
    ), repos='https://cloud.r-project.org/')"

# Install mcptools
RUN R -e "remotes::install_github('posit-dev/mcptools')"

# Set working directory
WORKDIR /workspace

# Expose MCP server ports
EXPOSE 3000 3001 3002

# Environment variables
ENV R_LIBS_USER=/workspace/renv/library
ENV RENV_PATHS_CACHE=/workspace/renv/cache

# Default: start MCP server
CMD ["R", "-e", "mcptools::mcp_server()"]

得: 項目根有 Dockerfilerocker/r-ver 基像、系依、mcptools 裝、MCP 伺為默令。

敗則: 驗基像合汝 R 版。若 remotes::install_github 敗,察 gitlibgit2-dev 於系依層。

第二步:建 docker-compose.yml

version: '3.8'

services:
  mcp-server:
    build:
      context: .
      dockerfile: Dockerfile
    container_name: r-mcp-server
    image: r-mcp-server:latest

    volumes:
      - /path/to/projects:/workspace
      - renv-cache:/workspace/renv/cache

    stdin_open: true
    tty: true

    network_mode: "host"

    environment:
      - TERM=xterm-256color
      - R_LIBS_USER=/workspace/renv/library

    restart: unless-stopped

volumes:
  renv-cache:
    driver: local

network_mode: "host" 保 MCP 伺埠於 localhost 可訪。

得: 項目根有 docker-compose.yml 附 MCP 伺服、項目檔與 renv 緩之卷掛、stdin_open/tty 啟為 stdio 傳。

敗則: 若卷徑誤,改 /path/to/projects 為實項徑。Windows/WSL 則用 /mnt/c/.../mnt/d/... 徑。

第三步:建而啟

docker compose build
docker compose up -d

得: 容啟附 MCP 伺行。

敗則:docker compose logs mcp-server 察誌。常問:

  • 缺 R 包:加於 Dockerfile RUN 裝步
  • 埠已用:改露埠或止衝服

第四步:連 Claude Code 於容

stdio 傳(容須附 stdin 續行):

claude mcp add r-mcp-docker stdio "docker" "exec" "-i" "r-mcp-server" "R" "-e" "mcptools::mcp_server()"

HTTP 傳(若 MCP 伺支):

{
  "mcpServers": {
    "r-mcp-docker": {
      "type": "http",
      "url": "http://localhost:3000/mcp"
    }
  }
}

得: Claude Code 之 MCP 設含 r-mcp-docker 條,claude mcp list 示新伺。

敗則: stdio 傳則確容名合(r-mcp-server)且以 docker ps 察容行。HTTP 傳則驗埠露且可達以 curl http://localhost:3000/mcp

第五步:驗連

# Check container is running
docker ps | grep mcp-server

# Test R session inside container
docker exec -it r-mcp-server R -e "sessionInfo()"

# Verify mcptools is available
docker exec -it r-mcp-server R -e "library(mcptools)"

得: docker psr-mcp-server 容行,sessionInfo() 返期 R 版,library(mcptools) 載無誤。

敗則: 若容不行,察 docker compose logs mcp-server 啟誤。若 mcptools 載敗,重建像保包正裝。

第六步:加自定 MCP 具

加項特 MCP 具,掛 R 腳:

volumes:
  - ./mcp-tools:/mcp-tools

於 CMD 中載:

CMD ["R", "-e", "source('/mcp-tools/custom_tools.R'); mcptools::mcp_server()"]

得: 自 R 腳於容內 /mcp-tools/ 可訪,MCP 伺啟時載之與默具並。

敗則: 驗卷掛徑以 docker exec -it r-mcp-server ls /mcp-tools/。若腳 source 敗,察自具之缺依。

  • 容建無誤
  • 容內 MCP 伺啟
  • Claude Code 可連於容伺
  • MCP 具應請
  • 容清重啟
  • 卷掛許訪項檔

  • stdin/tty 之需:MCP stdio 傳需 stdin_open: truetty: true
  • 網隔:默 Docker 網或阻 localhost 訪。用 network_mode: "host" 或露特埠。
  • 包版:固 mcptools 於特提交為可復
  • 像大:mcptools 附依可大。產考多階建。
  • Windows Docker 徑:於 Windows 附 WSL 行 Docker Desktop 時徑映異

  • create-r-dockerfile - R 之基 Dockerfile 式
  • setup-docker-compose - compose 設詳
  • configure-mcp-server - 無 Docker 之 MCP 伺設
  • troubleshoot-mcp-connection - 察 MCP 連之問

Repositorio GitHub

pjt222/agent-almanac
Ruta: i18n/wenyan/skills/containerize-mcp-server
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Habilidades relacionadas

content-collections

Meta

Esta habilidad proporciona una configuración probada en producción para Content Collections, una herramienta centrada en TypeScript que transforma archivos Markdown/MDX en colecciones de datos con tipado seguro mediante validación Zod. Úsala al construir blogs, sitios de documentación o aplicaciones Vite + React con mucho contenido para garantizar seguridad de tipos y validación automática de contenido. Abarca todo, desde la configuración del plugin de Vite y compilación MDX hasta la optimización de despliegue y validación de esquemas.

Ver habilidad

polymarket

Meta

Esta habilidad permite a los desarrolladores crear aplicaciones con la plataforma de mercados de predicción Polymarket, incluyendo la integración de API para operaciones y datos de mercado. También proporciona transmisión de datos en tiempo real a través de WebSocket para monitorear operaciones en vivo y actividad del mercado. Úsela para implementar estrategias de trading o crear herramientas que procesen actualizaciones de mercado en tiempo real.

Ver habilidad

creating-opencode-plugins

Meta

Esta habilidad ayuda a los desarrolladores a crear complementos de OpenCode que se conectan a más de 25 tipos de eventos, como comandos, archivos y operaciones LSP. Proporciona la estructura del complemento, las especificaciones de la API de eventos y los patrones de implementación para módulos en JavaScript/TypeScript. Úsala cuando necesites interceptar, monitorear o extender el ciclo de vida del asistente de IA de OpenCode con lógica personalizada basada en eventos.

Ver habilidad

sglang

Meta

SGLang es un framework de alto rendimiento para el servicio de LLM que se especializa en generación rápida y estructurada para JSON, expresiones regulares y flujos de trabajo de agentes utilizando su caché de prefijos RadixAttention. Ofrece una inferencia significativamente más rápida, especialmente para tareas con prefijos repetidos, lo que lo hace ideal para salidas complejas y estructuradas, y conversaciones multiturno. Elige SGLang sobre alternativas como vLLM cuando necesites decodificación restringida o estés construyendo aplicaciones con uso extensivo de prefijos compartidos.

Ver habilidad