From zeabur
Manages Zeabur service environment variables via CLI: create, update, delete, list, import from .env, and troubleshoot empty vars, shell expansion, SERVICE_NOT_FOUND.
npx claudepluginhub zeabur/agent-skills --plugin zeaburThis skill uses the workspace's default tool permissions.
> **Always use `npx zeabur@latest` to invoke Zeabur CLI.** Never use `zeabur` directly or any other installation method. If `npx` is not available, install Node.js first.
Updates Zeabur service environment variables, restarts services, or changes image tags without full redeploy. Use for fixing config, adding vars, or version upgrades.
Manages environment variables handler operations in DevOps basics, providing step-by-step guidance, best practices, and configurations for git, docker, CI/CD, infrastructure fundamentals.
Configures environment variables, secrets, and env groups on Render. Helps set vars, wire secrets between services, create groups, use generateValue/sync:false, or troubleshoot issues in Blueprints/Dashboard.
Share bugs, ideas, or general feedback.
Always use
npx zeabur@latestto invoke Zeabur CLI. Never usezeaburdirectly or any other installation method. Ifnpxis not available, install Node.js first.Do not guess CLI syntax. Only
create,update,delete,env, andlistare valid subcommands. Subcommands likesetoradddo not exist and will silently fail with no error output.
--id not --name — name lookup is unreliable${VAR} gets empty — shell expands before CLI receives; use single quotesvariable env replaces ALL variables — it overwrites the entire variable set with the .env file contents; existing variables not in the file will be removedCreates new variables. Errors if a key already exists — use update to change existing keys.
# Always use service ID — use the `zeabur-service-list` skill to get it
npx zeabur@latest variable create --id <service-id> \
-k "KEY1=value1" \
-k "KEY2=value2" \
-y -i=false
Updates only the specified keys. Does NOT clear other variables.
npx zeabur@latest variable update --id <service-id> \
-k "KEY1=new_value1" \
-k "KEY2=new_value2" \
-y -i=false
Deletes only the specified keys.
npx zeabur@latest variable delete --id <service-id> \
--delete-keys "KEY1" \
--delete-keys "KEY2" \
-y -i=false
npx zeabur@latest variable list --id <service-id> -i=false
Warning: This replaces ALL variables on the service with the contents of the .env file. Existing variables not in the file will be removed.
npx zeabur@latest variable env --id <service-id> -f .env
After running env, you must restart the service manually to apply changes.
Warning: The CLI
-kflag uses Cobra'sStringToStringVarparser which cannot reliably handle values containing${}, even with single quotes. The value may be truncated or emptied. See zeabur/cli#201.
# WRONG — shell expands ${VAR} to empty
npx zeabur@latest variable create --id <service-id> -k "REDIS_URL=${REDIS_URI_INTERNAL}" -y -i=false
# STILL UNRELIABLE — single quotes prevent shell expansion but Cobra's CSV parser may still mangle the value
npx zeabur@latest variable create --id <service-id> -k 'REDIS_URL=${REDIS_URI_INTERNAL}' -y -i=false
# RECOMMENDED — set variable references in Zeabur Dashboard
# Or use GraphQL API with updateEnvironmentVariable(data: Map!) mutation
For cross-service variable references like ${POSTGRES_CONNECTION_STRING} (Zeabur uses a flat namespace — all exposed variables from other services are merged directly, no service prefix needed), always use the Zeabur Dashboard until the CLI bug is fixed.
| Need | Command | Behavior |
|---|---|---|
| Add new vars | npx zeabur@latest variable create --id <service-id> -k "K=V" -y -i=false | Errors if key exists |
| Change existing vars | npx zeabur@latest variable update --id <service-id> -k "K=V" -y -i=false | Only updates specified keys |
| Remove specific vars | npx zeabur@latest variable delete --id <service-id> --delete-keys "K" -y -i=false | Only removes specified keys |
| Overwrite all vars from file | npx zeabur@latest variable env --id <service-id> -f .env | Replaces entire variable set |
| View vars | npx zeabur@latest variable list --id <service-id> -i=false | Read-only |