スキル一覧に戻る

create-r-dockerfile

pjt222
更新日 Yesterday
2 閲覧
17
2
17
GitHubで表示
メタmcp

について

このClaude Skillは、rockerベースイメージを使用してRプロジェクト向けに最適化されたDockerfileを生成します。システム依存関係の処理、Rパッケージのインストール、renv統合をレイヤー順序付けで実装し、高速なリビルドを実現します。Rアプリケーションのコンテナ化、再現可能な環境の構築、ShinyやPlumberなどのRベースサービスのデプロイにご利用ください。

クイックインストール

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/create-r-dockerfile

このコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします

ドキュメント


name: create-r-dockerfile description: > 为 R 项目创建基于 rocker 基础镜像的 Dockerfile。涵盖系统依赖安装、 R 包安装、renv 集成以及优化的层排序以实现快速重建。适用于容器化 R 应用程序或分析、创建可重现的 R 环境、部署基于 R 的服务(Shiny、 Plumber、MCP 服务器),或在多台机器间建立一致的开发环境。 license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: containerization complexity: intermediate language: Docker tags: docker, r, rocker, container, reproducibility locale: zh-CN source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16

创建 R Dockerfile

使用 rocker 基础镜像为 R 项目构建 Dockerfile,实现规范的依赖管理。

适用场景

  • 容器化 R 应用程序或分析
  • 创建可重现的 R 环境
  • 部署基于 R 的服务(Shiny、Plumber、MCP 服务器)
  • 建立一致的开发环境

输入

  • 必需:带有依赖的 R 项目(DESCRIPTION 或 renv.lock)
  • 必需:用途(开发、生产或服务)
  • 可选:R 版本(默认:最新稳定版)
  • 可选:所需的额外系统库

步骤

第 1 步:选择基础镜像

用途基础镜像大小
最小 R 运行时rocker/r-ver:4.5.0~800MB
包含 tidyverserocker/tidyverse:4.5.0~1.8GB
包含 RStudio Serverrocker/rstudio:4.5.0~1.9GB
Shiny 服务器rocker/shiny-verse:4.5.0~2GB

预期结果: 选择了与项目需求匹配且无不必要膨胀的基础镜像。

失败处理: 如果不确定使用哪个镜像,从 rocker/r-ver(最小化)开始,按需添加包。请查看 rocker-org 获取完整的镜像目录。

第 2 步:编写 Dockerfile

FROM rocker/r-ver:4.5.0

# Install system dependencies
# Group by purpose for clarity
RUN apt-get update && apt-get install -y \
    # HTTP/SSL
    libcurl4-openssl-dev \
    libssl-dev \
    # XML processing
    libxml2-dev \
    # Git integration
    libgit2-dev \
    libssh2-1-dev \
    # Graphics
    libfontconfig1-dev \
    libharfbuzz-dev \
    libfribidi-dev \
    libfreetype6-dev \
    libpng-dev \
    libtiff5-dev \
    libjpeg-dev \
    # Utilities
    git \
    curl \
    && rm -rf /var/lib/apt/lists/*

# Install R packages
# Order: least-changing first for cache efficiency
RUN R -e "install.packages(c( \
    'remotes', \
    'devtools', \
    'renv' \
    ), repos='https://cloud.r-project.org/')"

# Set working directory
WORKDIR /workspace

# Copy renv files first (cache layer)
COPY renv.lock renv.lock
COPY renv/activate.R renv/activate.R

# Restore packages from lockfile
RUN R -e "renv::restore()"

# Copy project files
COPY . .

# Default command
CMD ["R"]

预期结果: Dockerfile 使用 docker build -t myproject . 成功构建。

失败处理: 如果在 apt-get install 期间构建失败,请检查目标发行版(Debian)的包名称。如果 renv::restore() 失败,请确保 renv.lockrenv/activate.R 在 restore 步骤之前被复制。

第 3 步:创建 .dockerignore

.git
.Rproj.user
.Rhistory
.RData
renv/library
renv/cache
renv/staging
docs/
*.tar.gz

预期结果: .dockerignore 从 Docker 上下文中排除了 Git 历史、IDE 文件、本地 renv 库和构建产物。

失败处理: 如果 Docker 构建仍然复制了不需要的文件,请验证 .dockerignore 与 Dockerfile 位于同一目录,并使用了正确的 glob 模式。

第 4 步:构建和测试

docker build -t r-project:latest .
docker run --rm -it r-project:latest R -e "sessionInfo()"

预期结果: 容器以正确的 R 版本启动,所有包可用。sessionInfo() 输出确认预期的 R 版本。

失败处理: 检查构建日志中的系统依赖错误。向 apt-get install 层添加缺失的 -dev 包。

第 5 步:为生产优化

对于生产部署,使用多阶段构建:

# Build stage
FROM rocker/r-ver:4.5.0 AS builder
RUN apt-get update && apt-get install -y libcurl4-openssl-dev libssl-dev
COPY renv.lock .
RUN R -e "install.packages('renv'); renv::restore()"

# Runtime stage
FROM rocker/r-ver:4.5.0
COPY --from=builder /usr/local/lib/R/site-library /usr/local/lib/R/site-library
COPY . /app
WORKDIR /app
CMD ["Rscript", "main.R"]

预期结果: 多阶段构建生成更小的最终镜像。运行时阶段仅包含已编译的 R 包,不包含构建工具。

失败处理: 如果包在运行时阶段无法加载,请确保 COPY --from=builder 中的库路径与 R 安装包的位置匹配。在两个阶段中使用 R -e ".libPaths()" 检查。

验证清单

  • docker build 无错误完成
  • 容器启动且 R 会话正常工作
  • 所有必需的包可用
  • .dockerignore 排除了不必要的文件
  • 镜像大小对于用例来说是合理的
  • 仅代码更改时重建速度快(层缓存有效)

常见问题

  • 缺少系统依赖:含编译代码的 R 包需要 -dev 库。检查 install.packages() 期间的错误消息
  • 层缓存失效:在安装包之前复制所有文件会导致每次代码更改都使缓存失效。先复制 lockfile。
  • 镜像过大:在 apt-get install 后使用 rm -rf /var/lib/apt/lists/*。考虑多阶段构建。
  • 时区问题:添加 ENV TZ=UTC 或安装 tzdata 以支持时区感知操作
  • 以 root 运行:为生产环境添加非 root 用户:RUN useradd -m appuser && USER appuser

示例

# Development container with mounted source
docker run --rm -it -v $(pwd):/workspace r-project:latest R

# Plumber API service
docker run -d -p 8000:8000 r-api:latest

# Shiny app
docker run -d -p 3838:3838 r-shiny:latest

相关技能

  • setup-docker-compose - 编排多个容器
  • containerize-mcp-server - MCP R 服务器的特殊场景
  • optimize-docker-build-cache - 高级缓存策略
  • manage-renv-dependencies - renv.lock 作为 Docker 构建的输入

GitHub リポジトリ

pjt222/agent-almanac
パス: i18n/zh-CN/skills/create-r-dockerfile
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

関連スキル

content-collections

メタ

このスキルは、Content Collections(Markdown/MDXファイルを型安全なデータコレクションに変換するTypeScriptファーストのツール)の本番環境でテストされた設定を提供します。Zodバリデーションによる型安全性を実現し、ブログ、ドキュメントサイト、コンテンツ重視のVite + Reactアプリケーション構築時にご利用ください。Viteプラグインの設定、MDXコンパイルから、デプロイ最適化、スキーマバリデーションまで、すべてを網羅しています。

スキルを見る

polymarket

メタ

このスキルは、開発者がPolymarket予測市場プラットフォームを活用したアプリケーション構築を可能にします。API統合による取引や市場データの取得に加え、WebSocketを介したリアルタイムデータストリーミングにより、ライブ取引や市場活動を監視できます。取引戦略の実装や、ライブ市場更新を処理するツールの作成にご利用ください。

スキルを見る

creating-opencode-plugins

メタ

このスキルは、開発者がコマンド、ファイル、LSP操作など25種類以上のイベントタイプにフックするOpenCodeプラグインを作成することを支援します。JavaScript/TypeScriptモジュール向けに、プラグイン構造、イベントAPI仕様、および実装パターンを提供します。カスタムイベント駆動ロジックでOpenCode AIアシスタントのライフサイクルをインターセプト、監視、または拡張する必要がある場合にご利用ください。

スキルを見る

sglang

メタ

SGLangは、高性能なLLMサービングフレームワークであり、RadixAttentionプレフィックスキャッシュを活用したJSON、正規表現、エージェントワークフロー向けの高速で構造化された生成を特長とします。特にプレフィックスが繰り返されるタスクにおいて、大幅に高速な推論を実現し、複雑な構造化出力やマルチターン対話に最適です。制約付きデコードが必要な場合や、広範なプレフィックス共有を伴うアプリケーションを構築する場合は、vLLMなどの代替案ではなくSGLangを選択してください。

スキルを見る