i18n/de/skills/deploy-shiny-app/SKILL.md
Shiny-Anwendungen auf shinyapps.io, Posit Connect oder als Docker-Container deployen. Behandelt Authentifizierung, Dependency-Management, Deployment- Konfiguration und Post-Deployment-Verifikation. Verwenden, wenn eine Shiny- App einem breiteren Publikum zugänglich gemacht oder eine reproduzierbare Deployment-Pipeline eingerichtet werden soll.
npx skillsauth add pjt222/agent-almanac deploy-shiny-appInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Eine Shiny-App auf shinyapps.io, Posit Connect oder als Docker-Container für den Produktionseinsatz deployen.
shinyapps.io, posit-connect oder dockerSicherstellen, dass alle App-Dependencies deklariert sind.
# Alle Packages die App verwendet auflisten
renv::dependencies("app.R")
# Oder für golem-Pakete:
renv::dependencies(".")
# renv-Lockfile erstellen/aktualisieren
renv::snapshot()
DESCRIPTION-Datei (für golem-Pakete) prüfen:
Imports:
shiny,
dplyr,
ggplot2
Erwartet: Alle Dependencies dokumentiert. renv.lock oder DESCRIPTION up-to-date.
Bei Fehler: Wenn fehlende Packages nach dem Deployment auftreten, renv::dependencies() erneut ausführen und fehlende Packages zur DESCRIPTION hinzufügen.
rsconnect einrichten und auf shinyapps.io deployen.
install.packages("rsconnect")
# Authentifizierung (von shinyapps.io Dashboard kopieren)
# Account → Tokens → Add Token → Show → Copy to Clipboard
rsconnect::setAccountInfo(
name = "dein-account-name",
token = "DEIN_TOKEN",
secret = "DEIN_SECRET"
)
# Deployen
rsconnect::deployApp(
appDir = ".", # App-Verzeichnis
appName = "meine-app", # URL-Name (muss eindeutig sein)
forceUpdate = TRUE # Bestehende Deployment überschreiben
)
App-URL nach Deployment: https://dein-account-name.shinyapps.io/meine-app/
Erwartet: Deployment-Logs zeigen erfolgreiche Paket-Installation und App-Start. URL zugänglich im Browser.
Bei Fehler: Wenn Deployment fehlschlägt mit "package not found", das fehlende Package zur App-Verzeichnis-renv.lock hinzufügen. Deployment-Logs für spezifische Package-Fehler prüfen.
Das erfolgreiche Deployment und App-Verhalten prüfen.
# Deployment-Status prüfen
rsconnect::showLogs(appName = "meine-app")
# App-Informationen abfragen
rsconnect::appInfo(appName = "meine-app")
Manuell verifizieren:
Erwartet: App läuft korrekt auf deployed URL. Keine Fehler in Logs.
Bei Fehler: Bei Laufzeitfehlern in Deployment-Logs, fehlende Systembibliotheken oder R-Package-Versions-Konflikte prüfen. Lokale R-Version muss Deployment-Umgebung entsprechen.
Deployment-Prozess für zukünftige Updates dokumentieren.
# deploy.R (Deployment-Skript)
# Deployment-Konfiguration
APP_NAME <- "meine-app"
APP_DIR <- "."
# Dependencies prüfen
cat("Checking dependencies...\n")
renv::status()
# Auf shinyapps.io deployen
cat("Deploying to shinyapps.io...\n")
rsconnect::deployApp(
appDir = APP_DIR,
appName = APP_NAME,
forceUpdate = TRUE,
launch.browser = FALSE
)
cat("Deployment complete!\n")
cat(sprintf("URL: https://account.shinyapps.io/%s/\n", APP_NAME))
Erwartet: Rscript deploy.R führt vollständiges Deployment aus.
Bei Fehler: Wenn Skript auf Authentifizierungsfehler stößt, rsconnect-Credentials über rsconnect::setAccountInfo() neu setzen.
scaffold-shiny-app — App scaffolden vor Deploymenttest-shiny-app — App testen vor Deploymentdeploy-shinyproxy — Multi-App-Hosting mit Docker und ShinyProxyoptimize-shiny-performance — Performance vor Deployment optimierentesting
Launch all available agents in parallel waves for open-ended hypothesis generation on problems where the correct domain is unknown. Use when facing a cross-domain problem with no clear starting point, when single-agent approaches have stalled, or when diverse perspectives are more valuable than deep expertise. Produces a ranked hypothesis set with convergence analysis and adversarial refinement.
tools
Write integration tests for a Node.js CLI application using the built-in node:test module. Covers the exec helper pattern, output assertions, filesystem state verification, cleanup hooks, JSON output parsing, error case testing, and state restoration after destructive tests. Use when adding tests to an existing CLI, testing a new command, verifying adapter behavior across frameworks, or setting up CI for a CLI tool.
development
Screen a proposed trademark for conflicts and distinctiveness before filing. Covers trademark database searches (TMview, WIPO Global Brand Database, USPTO TESS), distinctiveness analysis using the Abercrombie spectrum, likelihood of confusion assessment using DuPont factors and EUIPO relative grounds, common law rights evaluation, and goods/services overlap analysis. Produces a conflict report with a risk matrix. Use before adopting a new brand name, logo, or slogan — distinct from patent prior art search, which uses different databases, legal frameworks, and analysis methods.
tools
Scaffold a new CLI command using Commander.js with options, action handler, three output modes (human-readable, quiet, JSON), and optional ceremony variant. Covers command naming, option design, shared context patterns, error handling, and integration testing. Use when adding a command to an existing Commander.js CLI, designing a new CLI tool from scratch, or standardizing command structure across a multi-command CLI.