返回技能列表

setup-docker-compose

pjt222
更新于 Yesterday
7 次查看
17
2
17
在 GitHub 上查看
文档aiapimcpdata

关于

This skill configures Docker Compose for multi-container R development environments, handling service definitions, volumes, networking, and environment variables. Use it when running R alongside databases or APIs, or to create reproducible development setups. It helps orchestrate R-based services and manage development versus production configurations.

快速安装

Claude Code

推荐
主要方式
npx skills add pjt222/agent-almanac -a claude-code
插件命令备选方式
/plugin add https://github.com/pjt222/agent-almanac
Git 克隆备选方式
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/setup-docker-compose

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档

設 Docker Compose

為 R 多容開發與展之境配 Docker Compose。

用時

  • R 與他服(庫、API)並行乃用
  • 設可重之開發境乃用
  • 為 R 之 MCP 服容編排乃用
  • 管環境變與卷掛乃用

  • 必要:R 服之 Dockerfile
  • 必要:所掛之項目目
  • 可選:他服(庫、緩、網服)
  • 可選:環境變之配

第一步:立 docker-compose.yml

version: '3.8'

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

    volumes:
      - .:/workspace
      - renv-cache:/workspace/renv/cache

    stdin_open: true
    tty: true

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

    command: R

    restart: unless-stopped

volumes:
  renv-cache:
    driver: local

得:docker-compose.yml 存附 R 服之定,含項目目與 renv 緩之卷掛、與 R 庫徑之環境變。

敗則:YAML 語法誤,以 docker compose config 驗。確縮以空(非 tab),含特字之串值皆引。

第二步:增他服(若需)

services:
  r-dev:
    # ... as above
    depends_on:
      - postgres
    environment:
      - DB_HOST=postgres
      - DB_PORT=5432

  postgres:
    image: postgres:16
    container_name: r-postgres
    environment:
      POSTGRES_DB: analysis
      POSTGRES_USER: ruser
      POSTGRES_PASSWORD_FILE: /run/secrets/db_password
    volumes:
      - pgdata:/var/lib/postgresql/data
    ports:
      - "5432:5432"

volumes:
  renv-cache:
  pgdata:

得:他服(如 PostgreSQL)已定附其卷、環境變、端映。R 服有 depends_on 指新服。

敗則:庫服啟敗,察 docker compose logs postgres 之初誤。驗 POSTGRES_PASSWORD_FILE 等指有效之密,或為開發改 POSTGRES_PASSWORD

第三步:配網

為需 localhost 之服(如 MCP 服):

services:
  r-dev:
    network_mode: "host"

為隔之網:

services:
  r-dev:
    networks:
      - app-network
    ports:
      - "3000:3000"

networks:
  app-network:
    driver: bridge

得:網配宜:host 模為需 localhost 之服(MCP 服),或橋網附明端映為隔之服。

敗則:服不能通,驗皆於同網。橋網用服名為主機名(如 postgres,非 localhost)。host 模用 localhost 確端口無衝。

第四步:管環境變

.env 文件(git-ignored):

R_VERSION=4.5.0
GITHUB_PAT=your_token_here

於 compose 引:

services:
  r-dev:
    build:
      args:
        R_VERSION: ${R_VERSION}
    env_file:
      - .env

得:.env 文件存(git-ignored)附項目特之變,docker-compose.yml 引之以 env_file 或變插(${VAR})。

敗則:變不解,確 .envdocker-compose.yml 同目。行 docker compose config 觀解後之配。

第五步:建而行

# Build images
docker compose build

# Start services
docker compose up -d

# Attach to R session
docker compose exec r-dev R

# View logs
docker compose logs -f r-dev

# Stop services
docker compose down

得:諸服啟。R 會話可訪。

敗則:察 docker compose logs 之啟誤。常患:端口衝、缺環境變。

第六步:為開發立 override

docker-compose.override.yml 為本地開發設:

services:
  r-dev:
    volumes:
      - /path/to/local/packages:/extra-packages
    environment:
      - DEBUG=true

此自合於 docker-compose.yml

得:docker-compose.override.yml 存附開發特之設(額卷、調試旗),自施於 docker compose up

敗則:override 不效,驗文名確為 docker-compose.override.yml。行 docker compose config 確合。明 override 文件用 docker compose -f docker-compose.yml -f custom-override.yml up

  • docker compose build 成而無誤
  • docker compose up 啟諸服
  • 卷掛正共文件於主與容
  • 環境變於容內可得
  • 諸服可相通
  • docker compose down 潔止諸物

  • 卷掛之權:Linux 容或以 root 立文件。用 user: 指或修權
  • 端口衝:察主上既用同端之服
  • Docker Desktop vs CLIdocker compose(v2)vs docker-compose(v1)。用 v2
  • WSL 徑掛:自 WSL 掛 Windows 目用 /mnt/c/...
  • 命名卷 vs 綁掛:命名卷跨重建持;綁掛即映主之變

  • create-r-dockerfile — 立 compose 所引之 Dockerfile
  • containerize-mcp-server — MCP 服之 compose 配
  • optimize-docker-build-cache — 速 compose 之建

GitHub 仓库

pjt222/agent-almanac
路径: i18n/wenyan/skills/setup-docker-compose
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

railway-docs

文档

Railway Docs Skill可实时获取最新的Railway官方文档,确保回答的准确性。当开发者询问Railway功能特性、工作原理或分享docs.railway.com链接时,应优先使用此技能。它通过专门的LLM优化文档源提供最新信息,避免依赖过时记忆来回答技术问题。

查看技能

n8n-code-python

文档

该Skill为在n8n平台的Python代码节点中编写代码提供专家指导,特别适用于需要使用_input/_json/_node语法、Python标准库或了解n8n中Python限制的场景。它强调JavaScript应作为首选方案,仅当需要特定Python功能或对Python语法更熟悉时才使用Python。Skill提供了快速入门模板和关键注意事项,帮助开发者在n8n中高效编写Python代码。

查看技能

archon

文档

Archon Skill为开发者提供了基于RAG的语义搜索和项目任务管理功能,可通过REST API访问知识库。它支持文档搜索、网站爬取、文件上传和版本控制,适用于技术文档查询和项目管理场景。首次使用时需要配置Archon主机地址,建议在处理外部文档时优先使用该Skill。

查看技能

n8n-code-javascript

文档

这个Skill为n8n工作流中的JavaScript代码节点提供专业指导,涵盖数据处理、HTTP请求和日期操作等核心场景。它详细解释了如何正确使用n8n特有的`$input`/`$json`语法、`$helpers`工具以及DateTime对象,并包含关键的错误排查和模式选择建议。开发者通过该Skill能快速掌握Code节点的正确返回格式、数据访问方法和常见陷阱解决方案。

查看技能