MCP HubMCP Hub
스킬 목록으로 돌아가기

deploy-shiny-app

pjt222
업데이트됨 Yesterday
1 조회
17
2
17
GitHub에서 보기
문서general

정보

이 Claude Skill은 R Shiny 애플리케이션을 shinyapps.io, Posit Connect 또는 Docker 컨테이너에 자동으로 배포합니다. 설정 구성, 매니페스트 생성, Dockerfile 작성을 처리하여 로컬 개발 환경에서 호스팅 환경으로의 마이그레이션이나 컨테이너화된 배포 설정에 이상적입니다. 사용자를 위한 앱 배포 또는 자동화된 배포 파이프라인 구축에 활용하세요.

빠른 설치

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에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요

문서


name: deploy-shiny-app description: > 将 Shiny 应用程序部署到 shinyapps.io、Posit Connect 或 Docker 容器。涵盖 rsconnect 配置、清单生成、Dockerfile 创建及部署验证。适用于为外部或内部 用户发布 Shiny 应用、从本地开发迁移到托管环境、为 Kubernetes 或 Docker 部署容器化 Shiny 应用,或设置自动化部署流水线。 license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: shiny complexity: basic language: R tags: shiny, deployment, shinyapps-io, posit-connect, docker, rsconnect locale: zh-CN source_locale: en source_commit: 6f65f316 translator: claude-opus-4-6 translation_date: 2026-03-16

部署 Shiny 应用

将 Shiny 应用程序部署到 shinyapps.io、Posit Connect 或 Docker 容器。

适用场景

  • 为外部或内部用户发布 Shiny 应用
  • 从本地开发迁移到托管环境
  • 为 Kubernetes 或 Docker 部署容器化 Shiny 应用
  • 设置自动化部署流水线

输入

  • 必需:Shiny 应用路径
  • 必需:部署目标(shinyapps.io、Posit Connect 或 Docker)
  • 可选:账户名和令牌(用于 shinyapps.io/Connect)
  • 可选:实例大小偏好
  • 可选:自定义域名或 URL 路径

步骤

第 1 步:准备应用程序

确保应用程序是自包含且可部署的:

# 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 路径使用。

第 2 步 A:部署到 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 控制台 > 账户 > 令牌 处重新生成令牌。如果服务器上包安装失败,检查所有包是否在 CRAN 上可用——shinyapps.io 默认无法从 GitHub 安装。

第 2 步 B:部署到 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 仓库)。

第 2 步 C:使用 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

第 3 步:验证部署

# 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,或文件路径仅在本地存在。

第 4 步:配置监控(可选)

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 密钥和其他密钥必须在部署环境中单独配置,与代码分离。

相关技能

  • 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/zh-CN/skills/deploy-shiny-app
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

연관 스킬

railway-docs

문서

이 스킬은 Railway의 기능, 작동 방식 또는 특정 문서 URL에 대한 질문에 답하기 위해 최신 Railway 문서를 가져옵니다. 개발자들이 Railway의 공식 소스로부터 정확하고 최신 정보를 직접 받을 수 있도록 보장합니다. 사용자가 Railway의 작동 방식을 묻거나 Railway 문서를 참조할 때 사용하세요.

스킬 보기

n8n-code-python

문서

이 Claude Skill은 n8n의 Code 노드에서 Python 코드를 작성할 때 전문적인 지침을 제공하며, 특히 Python 표준 라이브러리 사용과 n8n의 특수 구문인 `_input`, `_json`, `_node` 작업에 중점을 둡니다. 이는 개발자가 n8n 내에서 Python의 제한 사항을 이해하도록 돕고, 대부분의 워크플로에는 JavaScript 사용을 권장하면서도 특정 데이터 변환 요구사항에 대한 Python 솔루션을 제안합니다.

스킬 보기

archon

문서

Archon 스킬은 REST API를 통해 RAG 기반 시맨틱 검색과 프로젝트 관리를 제공합니다. 이 스킬을 사용하여 문서 검색, 계층적 프로젝트/태스크 관리, 문서 업로드 기능을 갖춘 지식 검색을 수행할 수 있습니다. 외부 문서를 검색할 때는 다른 소스를 사용하기 전에 항상 Archon을 최우선으로 활용하세요.

스킬 보기

n8n-code-javascript

문서

이 Claude Skill은 n8n의 Code 노드에서 JavaScript 코드 작성에 대한 전문적인 지침을 제공합니다. `$input`/`$json` 변수, HTTP 헬퍼, DateTime 처리와 같은 필수적인 n8n 특정 구문을 다루며 일반적인 오류를 해결합니다. Code 노드에서 사용자 정의 JavaScript 처리가 필요한 n8n 워크플로우를 개발할 때 활용하세요.

스킬 보기