MCP HubMCP Hub
Volver a habilidades

deploy-shiny-app

pjt222
Actualizado Yesterday
2 vistas
17
2
17
Ver en GitHub
Metaaiautomation

Acerca de

Esta habilidad despliega aplicaciones Shiny en shinyapps.io, Posit Connect o contenedores Docker. Maneja configuración, generación de manifiestos, creación de Dockerfiles y verificación de despliegues. Úsela al publicar aplicaciones para usuarios, al pasar del desarrollo local al alojamiento, o al containerizar para despliegue en Kubernetes/Docker.

Instalación rápida

Claude Code

Recomendado
Principal
npx skills add pjt222/agent-almanac -a claude-code
Comando PluginAlternativo
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativo
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/deploy-shiny-app

Copia y pega este comando en Claude Code para instalar esta habilidad

Documentación

部署 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 — 部至產前之性能調

Repositorio GitHub

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

Habilidades relacionadas

content-collections

Meta

Esta habilidad proporciona una configuración probada en producción para Content Collections, una herramienta centrada en TypeScript que transforma archivos Markdown/MDX en colecciones de datos con tipado seguro mediante validación Zod. Úsala al construir blogs, sitios de documentación o aplicaciones Vite + React con mucho contenido para garantizar seguridad de tipos y validación automática de contenido. Abarca todo, desde la configuración del plugin de Vite y compilación MDX hasta la optimización de despliegue y validación de esquemas.

Ver habilidad

polymarket

Meta

Esta habilidad permite a los desarrolladores crear aplicaciones con la plataforma de mercados de predicción Polymarket, incluyendo la integración de API para operaciones y datos de mercado. También proporciona transmisión de datos en tiempo real a través de WebSocket para monitorear operaciones en vivo y actividad del mercado. Úsela para implementar estrategias de trading o crear herramientas que procesen actualizaciones de mercado en tiempo real.

Ver habilidad

creating-opencode-plugins

Meta

Esta habilidad ayuda a los desarrolladores a crear complementos de OpenCode que se conectan a más de 25 tipos de eventos, como comandos, archivos y operaciones LSP. Proporciona la estructura del complemento, las especificaciones de la API de eventos y los patrones de implementación para módulos en JavaScript/TypeScript. Úsala cuando necesites interceptar, monitorear o extender el ciclo de vida del asistente de IA de OpenCode con lógica personalizada basada en eventos.

Ver habilidad

sglang

Meta

SGLang es un framework de alto rendimiento para el servicio de LLM que se especializa en generación rápida y estructurada para JSON, expresiones regulares y flujos de trabajo de agentes utilizando su caché de prefijos RadixAttention. Ofrece una inferencia significativamente más rápida, especialmente para tareas con prefijos repetidos, lo que lo hace ideal para salidas complejas y estructuradas, y conversaciones multiturno. Elige SGLang sobre alternativas como vLLM cuando necesites decodificación restringida o estés construyendo aplicaciones con uso extensivo de prefijos compartidos.

Ver habilidad