U

use-railway

by @railwayappv
4.4(63)

管理Railway平台的资源模型,包括工作区和项目层级的组织与配置。

railway-platformcloud-deploymentpaasinfrastructure-managementdevopsGitHub
安装方式
npx skills add railwayapp/railway-skills --skill use-railway
compare_arrows

Before / After 效果对比

1
使用前

Railway平台资源管理混乱,工作区和项目配置不规范,导致资源浪费。团队协作效率低下,难以统一管理和部署应用。

使用后

规范化管理Railway平台资源,优化工作区和项目配置。提升资源利用率,简化部署流程,确保云基础设施高效稳定运行。

SKILL.md

use-railway

Use Railway

Railway resource model

Railway organizes infrastructure in a hierarchy:

  • Workspace is the billing and team scope. A user belongs to one or more workspaces.

  • Project is a collection of services under one workspace. It maps to one deployable unit of work.

  • Environment is an isolated configuration plane inside a project (for example, production, staging). Each environment has its own variables, config, and deployment history.

  • Service is a single deployable unit inside a project. It can be an app from a repo, a Docker image, or a managed database.

  • Bucket is an S3-compatible object storage resource inside a project. Buckets are created at the project level and deployed to environments. Each bucket has credentials (endpoint, access key, secret key) for S3-compatible access.

  • Deployment is a point-in-time release of a service in an environment. It has build logs, runtime logs, and a status lifecycle.

Most CLI commands operate on the linked project/environment/service context. Use railway status --json to see the context, and --project, --environment, --service flags to override.

Preflight

Before any mutation, verify context:

command -v railway                # CLI installed
railway whoami --json             # authenticated
railway --version                 # check CLI version
railway status --json             # linked project/environment/service

If the CLI is missing, guide the user to install it.

bash <(curl -fsSL cli.new) # Shell script (macOS, Linux, Windows via WSL)
brew install railway # Homebrew (macOS)
npm i -g @railway/cli # npm (macOS, Linux, Windows). Requires Node.js version 16 or higher.

If not authenticated, run railway login. If not linked, run railway link --project <id-or-name>.

If a command is not recognized (for example, railway environment edit), the CLI may be outdated. Upgrade with:

railway upgrade

Common quick operations

These are frequent enough to handle without loading a reference:

railway status --json                                    # current context
railway whoami --json                                    # auth and workspace info
railway project list --json                              # list projects
railway service status --all --json                      # all services in current context
railway variable list --service <svc> --json             # list variables
railway variable set KEY=value --service <svc>           # set a variable
railway logs --service <svc> --lines 200 --json          # recent logs
railway up --detach -m "<summary>"                       # deploy current directory
railway bucket list --json                               # list buckets in current environment
railway bucket info --bucket <name> --json               # bucket storage and object count
railway bucket credentials --bucket <name> --json        # S3-compatible credentials

Routing

For anything beyond quick operations, load the reference that matches the user's intent. Load only what you need, one reference is usually enough, two at most.

Intent Reference Use for

Create or connect resources setup.md Projects, services, databases, buckets, templates, workspaces

Ship code or manage releases deploy.md Deploy, redeploy, restart, build config, monorepo, Dockerfile

Change configuration configure.md Environments, variables, config patches, domains, networking

Check health or debug failures operate.md Status, logs, metrics, build/runtime triage, recovery

Request from API, docs, or community request.md Railway GraphQL API queries/mutations, metrics queries, Central Station, official docs

If the request spans two areas (for example, "deploy and then check if it's healthy"), load both references and compose one response.

Execution rules

  • Prefer Railway CLI. Fall back to scripts/railway-api.sh for operations the CLI doesn't expose.

  • Use --json output where available for reliable parsing.

  • Resolve context before mutation. Know which project, environment, and service you're acting on.

  • For destructive actions (delete service, remove deployment, drop database), confirm intent and state impact before executing.

  • After mutations, verify the result with a read-back command.

Composition patterns

Multi-step workflows follow natural chains:

  • Add object storage: setup (create bucket), setup (get credentials), configure (set S3 variables on app service)

  • First deploy: setup (create project + service), configure (set variables and source), deploy, operate (verify healthy)

  • Fix a failure: operate (triage logs), configure (fix config/variables), deploy (redeploy), operate (verify recovery)

  • Add a domain: configure (add domain + set port), operate (verify DNS and service health)

  • Docs to action: request (fetch docs answer), route to the relevant operational reference

When composing, return one unified response covering all steps. Don't ask the user to invoke each step separately.

Setup decision flow

When the user wants to create or deploy something, determine the right action from current context:

  • Run railway status --json in the current directory.

  • If linked: add a service to the existing project (railway add --service <name>). Do not create a new project unless the user explicitly says "new project" or "separate project".

  • If not linked: check the parent directory (cd .. && railway status --json).

Parent linked: this is likely a monorepo sub-app. Add a service and set rootDirectory to the sub-app path.

  • Parent not linked: run railway list --json and look for a project matching the directory name.

Match found: link to it (railway link --project <name>).

  • No match: create a new project (railway init --name <name>).

  • When multiple workspaces exist, match by name from railway whoami --json.

Naming heuristic: app names like "flappy-bird" or "my-api" are service names, not project names. Use the directory or repo name for the project.

Response format

For all operational responses, return:

  • What was done (action and scope).

  • The result (IDs, status, key output).

  • What to do next (or confirmation that the task is complete).

Keep output concise. Include command evidence only when it helps the user understand what happened. Weekly Installs1.0KRepositoryrailwayapp/rail…y-skillsGitHub Stars198First SeenFeb 25, 2026Security AuditsGen Agent Trust HubPassSocketPassSnykWarnInstalled oncodex1.0Kopencode999github-copilot996gemini-cli995kimi-cli995amp995

用户评价 (0)

发表评价

效果
易用性
文档
兼容性

暂无评价

统计数据

安装量3.8K
评分4.4 / 5.0
版本
更新日期2026年5月22日
对比案例1 组

用户评分

4.4(63)
5
24%
4
51%
3
24%
2
2%
1
0%

为此 Skill 评分

0.0

兼容平台

🔧Claude Code
🔧OpenClaw
🔧OpenCode
🔧Codex
🔧Gemini CLI
🔧GitHub Copilot
🔧Amp
🔧Kimi CLI

时间线

创建2026年3月17日
最后更新2026年5月22日