Skip to content

sablierapp/sablier

Sablier Banner

Go Report Card Discord OpenSSF Scorecard

Free and open-source software that starts workloads on demand and stops them after a period of inactivity.

It integrates with reverse proxy plugins (Traefik, Caddy, Nginx, Envoy, etc.) to intercept incoming requests, wake up sleeping workloads, and display a waiting page until they're ready.

Demo

Whether you're running on a resource-constrained device like a Raspberry Pi, managing a QA environment used only once a week, or reducing cloud costs by scaling idle workloads to zero — Sablier is built for you.

Key features:

Installation

You can install Sablier using one of the following methods:

Use the Docker image

Helm

Docker Pulls Docker Image Size (tag)

Choose one of the Docker images and run it with a sample configuration file:

docker run -p 10000:10000 -v /var/run/docker.sock:/var/run/docker.sock sablierapp/sablier:1.12.0

Tip

Verify the image signature to ensure authenticity:

gh attestation verify --owner sablierapp oci://sablierapp/sablier:1.12.0

Use the binary distribution

Helm

Grab the latest binary from the releases page and run it:

./sablier --help

Tip

Verify the binary signature to ensure authenticity:

gh attestation verify sablier-1.10.3-linux-amd64.tar.gz -R sablierapp/sablier

Compile your binary from the sources

git clone git@github.com:sablierapp/sablier.git
cd sablier
make
# Output will change depending on your distro
./sablier_draft_linux-amd64

Use the Helm Chart

Helm

Deploy Sablier to your Kubernetes cluster using the official Helm chart for production-ready deployments.

Add the Sablier Helm repository:

helm repo add sablierapp https://sablierapp.github.io/helm-charts
helm repo update

Install Sablier:

helm install sablier sablierapp/sablier

📚 Full Documentation | 💻 Chart Repository


Quick Start

Note

This quick start demonstrates Sablier with the Docker provider.

For other providers, see the Providers section.

1. Start your container to scale to zero

Run your container with Sablier labels:

docker run -d --health-cmd "/mimic healthcheck" -p 8080:80 --name mimic \
  --label sablier.enable=true \
  --label sablier.group=demo \
  sablierapp/mimic:v0.3.3 \
  -running -running-after=5s \
  -healthy=true -healthy-after=5s

Here we run sablierapp/mimic, a configurable web-server for testing purposes.

Caution

You should always use a healthcheck with your application that needs to be scaled to zero.

Without a healtheck, Sablier cannot distinguish a started container from a container ready to receive incoming requests.

2. Stop the Container

Stop the container to simulate a scaled-down state:

docker stop mimic

Tip

Sablier can automatically stop containers at startup using the --provider.auto-stop-on-startup flag, which will stop all containers with sablier.enable=true labels.

3. Start Sablier

Start the Sablier server with the Docker provider:

docker run --name sablier \
  -p 10000:10000 \
  -v /var/run/docker.sock:/var/run/docker.sock \
  sablierapp/sablier:1.10.5 \
  start --provider.name=docker

4. Request a Session

Call the Sablier API to start a session for the demo group:

curl -v http://localhost:10000/api/strategies/blocking\?group\=demo\&session_duration\=20s
* Request completely sent off
< HTTP/1.1 200 OK
< X-Sablier-Session-Status: ready

Sablier will start the mimic container automatically for 20 seconds..

Tip

Check out the Usage with Reverse Proxies section to integrate Sablier with Traefik, Caddy, Nginx, and more.

5. Verify the Container is Running

docker ps | grep mimic

6. Wait for Session Expiration

After the session duration (20 seconds in this example), Sablier will automatically stop the container.

# Wait 20 seconds, then check
docker ps -a | grep mimic

The container should be stopped.


Configuration

📚 Full Documentation

There are three ways to configure Sablier:

  1. In a configuration file
  2. As environment variables
  3. As command-line arguments

Configuration sources are evaluated in the order listed above with later methods overriding earlier ones.

If no value is provided for a given option, a default value is used.

Configuration File

At startup, Sablier searches for a configuration file named sablier.yml (or sablier.yaml) in:

  • /etc/sablier/
  • $XDG_CONFIG_HOME/
  • $HOME/.config/
  • . (the working directory)

You can override this using the configFile argument.

sablier --configFile=path/to/myconfigfile.yml
provider:
  # Provider to use to manage containers (docker, swarm, kubernetes, podman, proxmox_lxc)
  name: docker
  # Reject requests for containers/services that don't have the Sablier enable label
  reject-unlabeled-requests: false
  # Verify that the Sablier enable label is present when an instance expires
  verify-enabled-on-expiration: false
  docker:
    # Strategy to use when stopping containers (stop or pause)
    strategy: stop
server:
  # The server port to use
  port: 10000
  # The base path for the API
  base-path: /
  metrics:
    # Enable Prometheus metrics endpoint
    enabled: true
storage:
  # File path to save the state (default stateless)
  file:
sessions:
  # The default session duration (default 5m)
  default-duration: 5m
  # The expiration checking interval.
  # Higher duration gives less stress on CPU.
  # If you only use sessions of 1h, setting this to 5m is a good trade-off.
  expiration-interval: 20s
logging:
  level: info
strategy:
  dynamic:
    # Custom themes folder, will load all .html files recursively (default empty)
    custom-themes-path:
    # Show instances details by default in waiting UI
    show-details-by-default: true
    # Default theme used for dynamic strategy (default "hacker-terminal")
    default-theme: hacker-terminal
    # Default refresh frequency in the HTML page for dynamic strategy
    default-refresh-frequency: 5s
  blocking:
    # Default timeout used for blocking strategy (default 1m)
    default-timeout: 1m
webhooks:
  endpoints:
    # Notify an uptime-monitoring service every time an instance starts or stops.
    # - url: https://uptime.example.com/api/push/xxxxxxxx
    #   headers:
    #     Authorization: "Bearer <token>"
    #   events:
    #     - started
    #     - stopped
tracing:
  # Set enabled: true to export OpenTelemetry traces.
  enabled: false
  # exporterType selects the trace backend: "otlphttp" (default) or "stdout".
  exporterType: otlphttp
  # endpoint is the OTLP collector base URL (scheme + host + optional port).
  # For Jaeger: http://jaeger:4318
  # For Grafana Tempo: http://tempo:4318
  endpoint: http://localhost:4318
  # serviceName is the logical name that appears in the tracing backend.
  serviceName: sablier
  # samplingRate controls the fraction of requests traced (0.0 – 1.0).
  samplingRate: 1.0

Environment Variables

Environment variables follow the same structure as the configuration file and are prefixed with SABLIER_. For example:

strategy:
  dynamic:
    custom-themes-path: /my/path

becomes

SABLIER_STRATEGY_DYNAMIC_CUSTOM_THEMES_PATH=/my/path

Arguments

To list all available arguments:

sablier --help

# or

docker run sablierapp/sablier:1.10.4 --help

Command-line arguments follow the same structure as the configuration file. For example:

strategy:
  dynamic:
    custom-themes-path: /my/path

becomes

sablier start --strategy.dynamic.custom-themes-path /my/path

Providers

Docker

Docker

Sablier integrates seamlessly with Docker Engine to manage container lifecycle based on demand.

Features:

  • Connects to the Docker socket
  • Starts/Stops containers
  • Compatible with Docker Compose

📚 Full Documentation


Docker Swarm

Docker Swarm

Sablier supports Docker Swarm mode for managing services across a cluster of Docker engines.

Features:

  • Connects to the Docker socket (Manager node)
  • Scales services to 0 and back
  • Compatible with Docker Stack

📚 Full Documentation


Podman

Podman

Sablier works with Podman, the daemonless container engine, providing the same dynamic scaling capabilities as Docker.

Features:

  • Connects to the Podman socket
  • Starts/Stops containers
  • Supports rootless containers

📚 Full Documentation


Kubernetes

Kubernetes

Sablier provides native Kubernetes support for managing deployments, scaling workloads dynamically.

Features:

  • Connects to the Kubernetes API
  • Scales Deployments and StatefulSets to 0 and back
  • Supports in-cluster and out-of-cluster configuration

📚 Full Documentation


Proxmox LXC

Proxmox

Sablier supports Proxmox VE for managing LXC containers on demand via the Proxmox API.

Features:

  • Connects to the Proxmox VE API with token authentication
  • Starts/Stops LXC containers
  • Discovers containers by sablier tag

📚 Full Documentation

Scale Mode

By default, Sablier stops (or pauses) workloads when a session expires and restarts them on the next request. Scale mode is an alternative: instead of stopping a container, Sablier throttles its CPU and memory to a minimal idle allocation, then restores full resources the moment a new session arrives.

Because the container never stops, there is no cold-start latency — ideal for resource-constrained environments like a Raspberry Pi where you want to reclaim most of the hardware while keeping response times acceptable.

Scale mode is controlled entirely through labels:

labels:
  - "sablier.enable=true"
  - "sablier.group=myapp"
  # Idle state: keep running but throttle resources
  - "sablier.idle.replicas=1"
  - "sablier.idle.cpu=0.1"
  - "sablier.idle.memory=64m"
  # Active state: full resources when a session is requested
  - "sablier.active.replicas=1"
  - "sablier.active.cpu=2.0"
  - "sablier.active.memory=512m"
Label Description
sablier.idle.replicas Replica count while idle. Set to 0 to stop (default behaviour), 1+ to keep running.
sablier.idle.cpu CPU limit while idle (e.g. 0.1 for 10% of one core). Requires idle.replicas >= 1.
sablier.idle.memory Memory limit while idle (e.g. 64m). Requires idle.replicas >= 1.
sablier.active.replicas Replica count when a session is active.
sablier.active.cpu CPU limit restored when a session is active.
sablier.active.memory Memory limit restored when a session is active.

📚 Full Example


Webhooks

Sablier can POST a normalized JSON notification to one or more HTTP endpoints whenever a managed instance starts or stops. Because Sablier sits in front of every supported provider, webhooks act as a unified, provider-agnostic event stream — your receiver always gets the same payload structure regardless of the underlying runtime.

Common uses:

  • Push heartbeats to an uptime monitor such as Uptime Kuma
  • Trigger CI/CD pipelines or automation on instance lifecycle events
  • Feed a central observability or alerting bus

📚 Full Documentation


Observability

Metrics

Sablier exposes a Prometheus-compatible /metrics endpoint. Enable it in your configuration:

server:
  metrics:
    enabled: true

Tracing

Sablier supports distributed tracing via OpenTelemetry. When enabled, every incoming HTTP request and every call to the underlying container provider is captured as a span and exported to an OTLP-compatible backend such as Jaeger or Grafana Tempo. Trace context is propagated using the W3C TraceContext format, so if your reverse proxy injects a traceparent header, Sablier will join the existing trace.

tracing:
  enabled: true
  exporterType: otlphttp
  endpoint: http://localhost:4318
  serviceName: sablier
  samplingRate: 1.0

📚 Full Documentation


Usage with Reverse Proxies

Sablier is an API server that manages workload lifecycle. To automatically wake up workloads when users access your services, you can integrate Sablier with reverse proxy plugins.

These plugins intercept incoming requests, call the Sablier API to start sleeping workloads, and display a waiting page until they're ready.

Apache APISIX

Apache APISIX

Sablier integrates with Apache APISIX through a Proxy-WASM plugin, enabling dynamic scaling for your services.

Quick Start:

  1. Install the Sablier Proxy-WASM plugin
  2. Configure APISIX routes with Sablier plugin settings
  3. Define your scaling labels on target services

📚 Full Documentation | 💻 Plugin Repository


Caddy

Caddy

Sablier provides a native Caddy module for seamless integration with Caddy v2.

Quick Start:

  1. Build Caddy with the Sablier module using xcaddy
  2. Add Sablier directives to your Caddyfile
  3. Configure dynamic scaling rules

📚 Full Documentation | 💻 Plugin Repository


Envoy

Envoy

Sablier integrates with Envoy Proxy through a Proxy-WASM plugin for high-performance dynamic scaling.

Quick Start:

  1. Deploy the Sablier Proxy-WASM plugin
  2. Configure Envoy HTTP filters
  3. Set up scaling labels on your workloads

📚 Full Documentation | 💻 Plugin Repository


Istio

Istio

Sablier works with Istio service mesh using the Proxy-WASM plugin for intelligent traffic management.

Quick Start:

  1. Install the Sablier Proxy-WASM plugin in your Istio mesh
  2. Configure EnvoyFilter resources
  3. Annotate your services with Sablier labels

📚 Full Documentation | 💻 Plugin Repository


Nginx

Nginx

Sablier integrates with Nginx through a WASM module, bringing dynamic scaling to your Nginx deployments.

Quick Start:

  1. Build Nginx with WASM support
  2. Load the Sablier Proxy-WASM plugin
  3. Configure Nginx locations with Sablier directives

📚 Full Documentation | 💻 Plugin Repository


Traefik

Traefik

Sablier provides a powerful middleware plugin for Traefik, the cloud-native application proxy.

Quick Start:

  1. Add the Sablier plugin to your Traefik static configuration
  2. Create Sablier middleware in your dynamic configuration
  3. Apply the middleware to your routes

📚 Full Documentation | 💻 Plugin Repository

Community

Join our Discord server to discuss and get support!

Discord

Support

This project is maintained by a single developer in their free time. If you find Sablier useful, here are some ways you can show your support:

Star the repository - It helps others discover the project and motivates continued development

🤝 Contribute - Pull requests are always welcome! Whether it's:

  • Bug fixes
  • New features
  • Documentation improvements
  • Test coverage

📚 Share your usage - We'd love to see how you're using Sablier! Consider:

  • Opening a discussion to share your setup
  • Contributing examples of your deployment configurations
  • Writing a blog post or tutorial

💬 Engage with the community - Ask questions, report issues, or help others in discussions

Every contribution, no matter how small, makes a difference and is greatly appreciated! 🙏

For detailed support options, see SUPPORT.md.

Sponsor

If you find Sablier valuable and want to support its development, please consider sponsoring the project:

💖 Sponsor on GitHub - Your sponsorship helps keep this project maintained and actively developed

Your support helps:

  • Keep the project maintained and up-to-date
  • Dedicate more time to bug fixes and new features
  • Improve documentation and examples
  • Support the broader open-source ecosystem

Every contribution, no matter the size, makes a real difference. Thank you for considering! 🙏

DigitalOcean

This project is supported by:

About

Start your containers on demand, shut them down automatically when there's no activity. Docker, Docker Swarm Mode, Podman, Kubernetes and Proxmox LXC compatible.

Topics

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Sponsor this project

 

Packages

 
 
 

Contributors

Languages