create-r-dockerfile
について
このClaude Skillは、rockerベースイメージを使用してRプロジェクトの最適化されたDockerfileを生成します。システム依存関係の処理、Rパッケージのインストール、renv統合を扱い、リビルドを高速化するスマートなレイヤー順序付けを実装します。Rアプリケーションのコンテナ化、再現可能な環境の構築、ShinyやPlumber APIなどのRベースサービスのデプロイ時にご利用ください。
クイックインストール
Claude Code
推奨npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/create-r-dockerfileこのコマンドをClaude Codeにコピー&ペーストしてスキルをインストールします
ドキュメント
Create R Dockerfile
Dockerfile for R using rocker + dep mgmt.
Use When
- Containerize R app / analysis
- Repro R env
- Deploy R svcs (Shiny, Plumber, MCP)
- Consistent dev env
In
- Required: R proj + deps (DESCRIPTION / renv.lock)
- Required: Purpose (dev/prod/svc)
- Optional: R ver (def: latest stable)
- Optional: Extra sys libs
Do
Step 1: Base Img
| Use | Base | Size |
|---|---|---|
| Min R | rocker/r-ver:4.5.0 | ~800MB |
| Tidyverse | rocker/tidyverse:4.5.0 | ~1.8GB |
| RStudio Svr | rocker/rstudio:4.5.0 | ~1.9GB |
| Shiny | rocker/shiny-verse:4.5.0 | ~2GB |
Got: Base matches reqs, no bloat.
If err: Unsure → rocker/r-ver (min) + add pkgs. See rocker-org catalog.
Step 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"]
Got: docker build -t myproject . builds OK.
If err: apt-get install fail → check pkg names (Debian). renv::restore() fail → ensure renv.lock + renv/activate.R copied before restore.
Step 3: .dockerignore
.git
.Rproj.user
.Rhistory
.RData
renv/library
renv/cache
renv/staging
docs/
*.tar.gz
Got: .dockerignore excludes git, IDE, local renv lib, artifacts.
If err: Build still copies unwanted → verify .dockerignore in same dir as Dockerfile, correct glob.
Step 4: Build + Test
docker build -t r-project:latest .
docker run --rm -it r-project:latest R -e "sessionInfo()"
Got: Container starts, R ver correct, pkgs avail. sessionInfo() confirms.
If err: Check build logs for sys dep err. Add missing -dev pkgs.
Step 5: Prod Optimize
Multi-stage:
# 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"]
Got: Multi-stage → smaller final img. Runtime = compiled R pkgs only.
If err: Pkgs fail load in runtime → lib path in COPY --from=builder must match R install path. Check: R -e ".libPaths()" in both.
Check
-
docker buildno err - Container starts, R works
- All req pkgs avail
-
.dockerignoreexcludes junk - Img size reasonable
- Fast rebuild on code-only change (cache works)
Traps
- Missing sys deps: Compiled R pkgs need
-devlibs. Checkinstall.packages()err msgs - Cache invalidation: Copy all files pre-install → cache invalidated on code change. Copy lockfile first.
- Large imgs:
rm -rf /var/lib/apt/lists/*afterapt-get install. Multi-stage. - Timezone:
ENV TZ=UTC/ installtzdatafor TZ-aware ops - Root user: Add non-root prod:
RUN useradd -m appuser && USER appuser
Examples
# 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— orchestrate multi containerscontainerize-mcp-server— MCP R svrsoptimize-docker-build-cache— cache strategiesmanage-renv-dependencies— renv.lock → Docker
GitHub リポジトリ
関連スキル
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を選択してください。
