返回技能列表

deploy-shiny-app

pjt222
更新于 Yesterday
5 次查看
17
2
17
在 GitHub 上查看
aiautomation

关于

This skill deploys Shiny applications to shinyapps.io, Posit Connect, or Docker containers. It handles configuration, manifest generation, Dockerfile creation, and deployment verification. Use it when publishing apps for users, moving from local development to hosting, or containerizing for Kubernetes/Docker deployment.

快速安装

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/deploy-shiny-app

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

技能文档

部署 Shiny 應用

將 Shiny 應用部至 shinyapps.io、Posit Connect 或 Docker 容器。

用時

  • 為外或內用者發布 Shiny 應用
  • 由本地開發移至宿主環境
  • 將 Shiny 應用容器化供 Kubernetes 或 Docker 部署
  • 立自動部署流水

  • 必要:Shiny 應用之路
  • 必要:部署目標(shinyapps.io、Posit Connect 或 Docker)
  • 可選:帳號名與令牌(供 shinyapps.io/Connect)
  • 可選:實例大小之偏好
  • 可選:自定域名或 URL 路

第一步:備應用

確應用自含可部:

# Check for missing dependencies
rsconnect::appDependencies("path/to/app")

# For golem apps, ensure DESCRIPTION lists all Imports
devtools::check()

# Verify the app runs cleanly
shiny::runApp("path/to/app")

驗此諸文件存:

  • app.R(或 ui.R + server.R
  • renv.lock(宜有,供可重現部署)
  • .Rprofile 於產中不得mcptools::mcp_session()

得: 應用本地無錯而行,所有依賴已捕。

敗則:appDependencies() 報缺包,裝之並更 renv.lock。若應用用系庫(如 gdal、curl),記之供 Docker 路。

第二步甲:部至 shinyapps.io

# One-time account setup
rsconnect::setAccountInfo(
  name = "your-account",
  token = Sys.getenv("SHINYAPPS_TOKEN"),
  secret = Sys.getenv("SHINYAPPS_SECRET")
)

# Deploy
rsconnect::deployApp(
  appDir = "path/to/app",
  appName = "my-app",
  appTitle = "My Application",
  account = "your-account",
  forceUpdate = TRUE
)

憑證存於 .Renviron(勿於碼):

# .Renviron
SHINYAPPS_TOKEN=your_token_here
SHINYAPPS_SECRET=your_secret_here

得: 應用已部,可訪於 https://your-account.shinyapps.io/my-app/

敗則: 若認證敗,於 shinyapps.io 控制臺 > Account > Tokens 重生令牌。若伺之包裝敗,察諸包皆於 CRAN——默認 shinyapps.io 不能由 GitHub 裝。

第二步乙:部至 Posit Connect

# Register server (one-time)
rsconnect::addServer(
  url = "https://connect.example.com",
  name = "production"
)

# Authenticate (one-time)
rsconnect::connectApiUser(
  account = "your-username",
  server = "production",
  apiKey = Sys.getenv("CONNECT_API_KEY")
)

# Deploy
rsconnect::deployApp(
  appDir = "path/to/app",
  appName = "my-app",
  server = "production",
  account = "your-username"
)

得: 應用已部,於 Posit Connect 實例可訪。

敗則: 若伺拒連,驗 API 鑰與伺 URL。若包裝敗,察 Connect 可訪所需庫(CRAN、內部 CRAN 樣庫)。

第二步丙:以 Docker 部

Dockerfile

FROM rocker/shiny-verse:4.4.0

# Install system dependencies
RUN apt-get update && apt-get install -y \
    libcurl4-openssl-dev \
    libssl-dev \
    libxml2-dev \
    && rm -rf /var/lib/apt/lists/*

# Install R packages
RUN R -e "install.packages(c('shiny', 'bslib', 'DT', 'plotly'))"

# Copy app
COPY . /srv/shiny-server/myapp/

# Configure Shiny Server
COPY shiny-server.conf /etc/shiny-server/shiny-server.conf

# Expose port
EXPOSE 3838

# Run
CMD ["/usr/bin/shiny-server"]

shiny-server.conf

run_as shiny;

server {
  listen 3838;

  location / {
    site_dir /srv/shiny-server/myapp;
    log_dir /var/log/shiny-server;
    directory_index on;
  }
}

建並行:

docker build -t myapp:latest .
docker run -p 3838:3838 myapp:latest

得: 應用於 http://localhost:3838 可訪。

敗則: 若建時包裝敗,於 apt-get install 加缺之系庫。若應用不載,察 Shiny Server 日誌:docker exec <container> cat /var/log/shiny-server/*.log

第三步:驗部署

# Check the deployed URL responds
response <- httr::GET("https://your-app-url/")
httr::status_code(response)  # Should be 200

# For Docker
response <- httr::GET("http://localhost:3838/")
httr::status_code(response)

人手驗之單:

  1. 應用無錯載
  2. 所有交互元應
  3. 部署環境中數據連可
  4. 認證/授權可(若有)

得: 應用以 HTTP 200 應,諸能可行。

敗則: 察部署平臺之伺日誌。常見問題:產中環境變量未設;數據庫連用 localhost 而非產 URL;僅本地存之文件路。

第四步:配監視(可選)

shinyapps.io

https://www.shinyapps.io/admin/#/applications 之控制臺監。

Posit Connect

# Check deployment status via API
connectapi::connect(
  server = "https://connect.example.com",
  api_key = Sys.getenv("CONNECT_API_KEY")
)

Docker

於 Dockerfile 加健檢:

HEALTHCHECK --interval=30s --timeout=10s --retries=3 \
  CMD curl -f http://localhost:3838/ || exit 1

得: 監視已為部署目標配。

敗則: 若健檢時時敗,加超時。Shiny 應用初載或慢應。

  • 應用無錯部
  • 部署 URL 以 HTTP 200 應
  • 諸交互能於產可行
  • 環境變量/秘密已配(非硬編)
  • 憑證存於 .Renviron 或 CI 秘密,非碼
  • renv.lock 已提交以求可重現之依賴解析

  • 硬編文件路:以 system.file()(供包數據)或環境變量(供外資)替絕對路。
  • 唯開發之依賴:勿部載 mcptools::mcp_session()devtools.Rprofile。用條件載或分離配置。
  • Docker 中缺系庫:sf、curl、xml2 等 R 包需系庫。於 Dockerfile 之 apt-get install 加之。
  • shinyapps.io 唯 CRAN 包:shinyapps.io 默認唯由 CRAN 裝。唯 GitHub 之包需 remotes 包並於部署明裝。
  • 忘環境變量:數據庫憑證、API 鑰及他秘密必須於部署環境外碼獨配。

Related Skills

  • scaffold-shiny-app — 部前建應用結構
  • create-r-dockerfile — R 項目之詳 Docker 配
  • setup-docker-compose — Shiny 與數據庫之多容器設
  • setup-github-actions-ci — CI/CD 含自動部署
  • optimize-shiny-performance — 部至產前之性能調

GitHub 仓库

pjt222/agent-almanac
路径: i18n/wenyan/skills/deploy-shiny-app
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

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是理想选择。

查看技能