create-r-dockerfile
关于
This skill generates Dockerfiles for R projects using the rocker base images. It handles system dependencies, R package installation, renv integration, and optimizes layer ordering for efficient rebuilds. Use it when containerizing R applications, creating reproducible environments, or deploying R-based services like Shiny or Plumber APIs.
快速安装
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 中复制并粘贴此命令以安装该技能
技能文档
建 R Dockerfile
為 R 項目以 rocker 基像建 Dockerfile,含正依管。
用時
- 將 R 應用或析入容器
- 建可重現之 R 境
- 布 R 服(Shiny、Plumber、MCP 服)
- 建一致之開發境
入
- 必要:有依之 R 項目(DESCRIPTION 或 renv.lock)
- 必要:志(開發、產、服)
- 可選:R 版(默最新穩)
- 可選:所需他系庫
法
第一步:擇基像
| 用案 | 基像 | 尺 |
|---|---|---|
| 最小 R 運 | rocker/r-ver:4.5.0 | ~800MB |
| 含 tidyverse | rocker/tidyverse:4.5.0 | ~1.8GB |
| 含 RStudio Server | rocker/rstudio:4.5.0 | ~1.9GB |
| Shiny 服 | rocker/shiny-verse:4.5.0 | ~2GB |
得: 擇合項需之基像而無贅。
敗則: 若疑用何像,始於 rocker/r-ver(最小),需時加包。全像目參 rocker-org。
第二步:書 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.lock 與 renv/activate.R 於 restore 前已複。
第三步:建 .dockerignore
.git
.Rproj.user
.Rhistory
.RData
renv/library
renv/cache
renv/staging
docs/
*.tar.gz
得: .dockerignore 排 Git 史、IDE 文件、本 renv 庫、建物於 Docker 脈之外。
敗則: 若 Docker 仍複不欲之文件,驗 .dockerignore 與 Dockerfile 同目錄,用正 glob 式。
第四步:建而試
docker build -t r-project:latest .
docker run --rm -it r-project:latest R -e "sessionInfo()"
得: 容器起,R 版正而諸包可用。sessionInfo() 驗期 R 版。
敗則: 察建誌之系依訛。加缺 -dev 包於 apt-get install 層。
第五步:為產優化
產布宜用多階建:
# 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以時區感操作 - 根運:產境加非根用者:
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 仓库
相关推荐技能
content-collections
元Content Collections 是一个 TypeScript 优先的构建工具,可将本地 Markdown/MDX 文件转换为类型安全的数据集合。它专为构建博客、文档站和内容密集型 Vite+React 应用而设计,提供基于 Zod 的自动模式验证。该工具涵盖从 Vite 插件配置、MDX 编译到生产环境部署的完整工作流。
polymarket
元这个Claude Skill为开发者提供完整的Polymarket预测市场开发支持,涵盖API调用、交易执行和市场数据分析。关键特性包括实时WebSocket数据流,可监控实时交易、订单和市场动态。开发者可用它构建预测市场应用、实施交易策略并集成实时市场预测功能。
creating-opencode-plugins
元该Skill帮助开发者创建OpenCode插件,用于接入命令、文件、LSP等25+种事件。它提供了插件结构、事件API规范和JavaScript/TypeScript实现模式,适合需要拦截操作、扩展功能或自定义事件处理的场景。开发者可通过它快速构建响应式模块来增强OpenCode AI助手的能力。
sglang
元SGLang是一个专为LLM设计的高性能推理框架,特别适用于需要结构化输出的场景。它通过RadixAttention前缀缓存技术,在处理JSON、正则表达式、工具调用等具有重复前缀的复杂工作流时,能实现极速生成。如果你正在构建智能体或多轮对话系统,并追求远超vLLM的推理性能,SGLang是理想选择。
