MCP HubMCP Hub
Volver a habilidades

containerize-mcp-server

pjt222
Actualizado 6 days ago
14 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 y creando entornos reproducibles. Cubre la integración con mcptools, configuración de transporte (stdio/HTTP) y conexión de Claude Code al contenedor. Úsela para distribuir servidores MCP o ejecutarlos junto con otros servicios contenedorizados.

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)

一:建 MCP 服之 Dockerfile

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()"]

得: Dockerfile 於項根含 rocker/r-ver 基像、系依、mcptools 裝、MCP 服為默令。

敗: 驗基像 tag 合 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 緩之卷掛、stdio 傳啟 stdin_open/tty

敗: 卷路誤→調 /path/to/projects 為實項目錄。Win/WSL 用 /mnt/c/.../mnt/d/...

三:建且啟

docker compose build
docker compose up -d

得: 容器啟含 MCP 服行。

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

  • R 包缺:加於 Dockerfile 裝步
  • 埠已佔:變露埠或停衝服

四:連 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 至具體 commit 以重現
  • 像大:mcptools + 依可大。生產慮多階建。
  • Win Docker 路:Win 上 Docker Desktop 含 WSL,路映異

  • 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-ultra/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