Using Zerops Setup Control (zsc)
Zerops Setup Control (zsc) is a cli tool / helper installed to all containers, runtime and build, which allows some direct modifications, like triggering scaling from inside the container, adding new technologies, making sure that commands (like migration) run only once (even when staring some high available setup with 3 containers)
Zsc is automatically installed in all containers and is available both in runtime and build environments.
Command Overview​
zsc --help
Zerops SetupControl CLI
Usage:
zsc [command]
Available Commands:
action Perform specific predefined actions within the container
backup-create creates a new backup of the specified stack
backup-current Create a new backup of the current stack
completion Generate the autocompletion script for the specified shell
connectSharedStorage Connect shared storage to the container
crontab Perform crontab actions defined in zerops.yml
execOnce Execute a command once for the provided key
fail-me Fail current container
help Help about any command
install Run install commands for the specified base
noop Infinitely blocking command that does nothing
scale Scale container CPU or memory instantly*
setSecretEnv Set an secret environment variable in the current stack context
test Run various tests
version application version
Flags:
-h, --help help for zsc
Use "zsc [command] --help" for more information about a command.
Available Commands​
backup-create and backup-current​
The backup-create
command lets you create a backup of any specified stack in your project, while backup-current
command creates a backup of the stack you're currently working in.
Backups include all the data and configurations of the stack at the time of backup creation. These can be used for recovery or creating duplicate environments.
connectSharedStorage​
This command lets you connect a shared storage volume to your service for persistent data storage.
crontab​
This command lets you manage scheduled tasks that are defined in your zerops.yml configuration.
execOnce​
This command is particularly useful in high-availability setups to ensure commands (like database migrations) run only once, even when starting multiple containers.
This command lets you execute a command exactly once across all containers in a service. Useful for database migrations in high-availability setups.
fail-me​
This command lets you deliberately fail the current container for testing purposes.
install​
You can install additional base technologies in your runtime container that weren't specified in the initial configuration.
The install
command allows you to add technologies that weren't specified in the initial base configuration.
Example usage in zerops.yml
:
noop​
An infinitely blocking command that does nothing and keeps the container alive so that it doesn't end because of an error. The command runs indefinitely until it receives a SIGTERM signal.
The noop
command is particularly useful for debugging build failures by keeping the container alive for investigation.
The --silent
flag suppresses any output from the command.
scale​
This command dynamically adjusts CPU or memory resources for the current container.
If there aren't enough resources available on the current node, using scale
may trigger a container move to another node. This will reset the scale duration.
# Scale CPU
zsc scale cpu auto # Reset to automatic scaling
zsc scale cpu 5 1h # Scale to 5 CPU cores for 1 hour
zsc scale cpu +2 30m # Add 2 CPU cores for 30 minutes
# Scale Memory
zsc scale memory auto # Reset to automatic scaling
zsc scale memory 5GB 1h # Scale to 5GB RAM for 1 hour
zsc scale memory +2.5GB 600s # Add 2.5GB RAM for 600 seconds
- Scaling takes effect within ~10 seconds
- Duration must be at least 10 minutes
- Supported values: "auto", "min", "max", or numeric values
- RAM values require units (KiB, MiB, GiB)
- CPU values must be integers without units
- Use "+" prefix for relative scaling
test tcp​
This command verifies TCP connectivity to a specified host and port.
<host>
: Server address to connect to<port>
: Port number to connect to--timeout <duration>
: Maximum test duration (default: 30s)--dialTimeout <duration>
: Single attempt timeout (default: 2s)-4
: Force IPv4-6
: Force IPv6
Example:
setSecretEnv​
This command sets a secret environment variable in the current stack context.
Examples:
version​
This command displays the current version of Zsc CLI.