Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tschaefer/supervisor
The Docker GitOps service :rocket:
https://github.com/tschaefer/supervisor
docker docker-compose gitops polling rails rest-api webhook
Last synced: 4 days ago
JSON representation
The Docker GitOps service :rocket:
- Host: GitHub
- URL: https://github.com/tschaefer/supervisor
- Owner: tschaefer
- License: mit
- Created: 2024-10-24T16:22:21.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2025-01-14T12:57:44.000Z (10 days ago)
- Last Synced: 2025-01-14T13:40:45.198Z (10 days ago)
- Topics: docker, docker-compose, gitops, polling, rails, rest-api, webhook
- Language: Ruby
- Homepage:
- Size: 531 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# Supervisor
Supervisor is a Docker GitOps service that allows you to manage `docker-compose` based stacks through a REST API. The minimal input required to manage stacks includes a unique name, a URL to the git repository hosting the stack files, and a strategy for updating the stack (either via polling or webhook). Authentication and authorization are handled via HTTP headers.
* [Supervisor](#supervisor)
* [Status](#status)
* [Features](#features)
* [Requirements](#requirements)
* [Running Supervisor](#running-supervisor)
* [Exposing Port and HTTPS Requirements](#exposing-port-and-https-requirements)
* [REST API](#rest-api)
* [Authentication](#authentication)
* [API Endpoints](#api-endpoints)
* [Creating a Stack](#creating-a-stack)
* [Parameters](#parameters)
* [List Stacks](#list-stacks)
* [Show Stack](#show-stack)
* [Show Stack Statistics](#show-stack-statistics)
* [Update Stack](#update-stack)
* [Delete Stack](#delete-stack)
* [Get Stack Log](#get-stack-log)
* [Control Stack](#control-stack)
* [Metrics](#metrics)
* [Dashboard](#dashboard)
* [License](#license)
* [Is it any good?](#is-it-any-good)## Status
[![GitHub Actions Workflow CI Status](https://img.shields.io/github/actions/workflow/status/tschaefer/supervisor/ci.yml?label=ci)](https://github.com/tschaefer/supervisor/actions)
[![GitHub Actions Workflow Docker Release Status](https://img.shields.io/github/actions/workflow/status/tschaefer/supervisor/docker-release.yml?label=docker-release)](https://github.com/tschaefer/supervisor/actions)[![GitHub Release](https://img.shields.io/github/v/release/tschaefer/supervisor)](https://github.com/tschaefer/supervisor/releases/latest)
[![Container image](https://img.shields.io/badge/image-latest-blue)](https://github.com/tschaefer/supervisor/pkgs/container/supervisor/latest)## Features
- Manage Docker Compose-based stacks via REST API
- GitOps strategy support:
- **Polling**: Define an interval to automatically pull updates.
- **Webhook**: Trigger updates via webhooks, with support for signatures.
- Supports Git repository authentication (username and token).
- Custom Docker Compose variables and additional Compose files can be passed with each stack.
- Secured with HTTP authorization headers.## Requirements
- Docker must be installed on the host system.
## Running Supervisor
To run Supervisor as a Docker container:
```
docker container run --name supervisor \
--detach \
--volume /var/run/docker.sock:/var/run/docker.sock \
--volume /var/lib/container/supervisor:/rails/storage \
--env SUPERVISOR_SECRET_KEY_BASE="af8758d92e3eccfbcc84a6bd6684060d" \
--env SUPERVISOR_API_KEY="8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--env SUPERVISOR_RAILS_LOG_LEVEL="info" \
--publish 3000:3000 \
ghcr.io/tschaefer/supervisor
```### Exposing Port and HTTPS Requirements
- The Supervisor container exposes **port 3000** for HTTP traffic but **only accepts HTTPS connections**.
- You need to set up a reverse proxy (such as Nginx or Traefik) to handle HTTPS termination and forward traffic to the container on port 3000.## REST API
You can interact with Supervisor via its REST API to manage stacks.
### Authentication
All requests to the API must be authorized using the `Authorization` HTTP header, which should contain the API key provided during setup.
```
--header "Authorization: Bearer "
```### API Endpoints
- **`POST /stacks`**: Create a new stack.
- **`GET /stacks`**: List all stacks.
- **`GET /stacks/`**: Show details of a specific stack.
- **`GET /stacks//stats`**: Show statistics for a specific stack.
- **`PATCH/PUT /stacks/`**: Update a stack.
- **`DELETE /stacks/`**: Delete a stack.
- **`POST /stacks//webhook`**: Trigger a stack update.
- **`POST /stacks//control`**: Control the stack (start, stop, restart, redeploy).
- **`GET /stacks//log`**: Retrieve last stack log entries or stream logs (Server-sent events).
- **`GET /up`**: Check the health of the Supervisor service. (No authorization required)### Creating a Stack
The following `curl` command demonstrates how to create a new stack using Supervisor's REST API:
```
curl --request POST \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
--json '{
"name": "whoami",
"git_repository": "https://github.com/tschaefer/infrastructure",
"git_username": "tschaefer",
"git_token": "github_pat_...FFF",
"git_reference": "refs/heads/main",
"compose_file": "lib/stack/whoami/docker-compose.yml",
"compose_includes": [
"lib/stack/whoami/includes/traefik.yml",
"lib/stack/whoami/includes/network.yml"
],
"compose_variables": {
"NETWORK_IPV4_WHOAMI": "172.18.100.111",
"NETWORK_ID": "core"
},
"strategy": "polling",
"polling_interval": "300"
"signature_header": "X-Hub-Signature-256",
"signature_secret": "2ede1091492a7c4205ae9c0ee9ed7376
}' \
https://supervisor.example.com/stacks
```#### Parameters
- `name`: Unique name for the stack.
- `git_repository`: URL to the git repository containing the stack's `docker-compose.yml` file.
- `git_username`: (Optional) Username for accessing the repository.
- `git_token`: (Optional) Token for accessing the repository.
- `git_reference`: Git reference (e.g., branch or tag) to track.
- `compose_file`: Path to the `docker-compose.yml` file in the repository.
- `compose_includes`: (Optional) A list of additional Compose files to be included.
- `compose_variables`: (Optional) Variables to pass to the compose file.
- `strategy`: GitOps strategy. Can be `polling` or `webhook`.
- `polling_interval`: (For `polling` strategy) Interval in seconds for polling the repository for changes.
- `signature_header` and `signature_secret`: (For `webhook` strategy) Additional data required for webhooks.Any update beside the `name`, `strategy` and required attributes will apply a redeploy of the stack.
### List Stacks
To retrieve a list of all managed stacks:
```
curl --request GET \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
https://supervisor.example.com/stacks/
```### Show Stack
To view the details of a specific stack (replace `` with the actual stack ID):
```
curl --request GET \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
https://supervisor.example.com/stacks/
```### Show Stack Statistics
To view statistics for a specific stack, such as the number of processed or failed runs and the last run timestamp:
```
curl --request GET \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
https://supervisor.example.com/stacks//stats
```### Update Stack
To update a stack (e.g., changing the `strategy`):
```
curl --request PATCH \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
--json '{ "strategy": "webhook" }' \
https://supervisor.example.com/stacks/
```### Delete Stack
To delete a stack:
```
curl --request DELETE \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
https://supervisor.example.com/stacks/
```### Get Stack Log
To retrieve logs for a stack (Server-sent events):
```
curl --request GET \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
--no-buffer \
https://supervisor.example.com/stacks//log?follow=true
```To retrieve the last log entries (default is 1, max is 100):
```
curl --request GET \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
https://supervisor.example.com/stacks//log?entries=50
```### Control Stack
To control a stack (start, stop, restart, redeploy):
```
curl --request POST \
--silent \
--header "Authorization: Bearer 8db7fde4-6a11-462e-ba27-6897b7c9281b" \
--verbose \
--json '{ "command": "start" }' \
https://supervisor.example.com/stacks//control
```## Metrics
To retrieve Prometheus metrics, you can access the
`http://supervisor.example.com:9394/metrics` endpoint.* `supervisor_total_stacks`: The total number of stacks. (gauge)
* `supervisor_total_healthy_stacks`: The total number of healthy stacks. (gauge)
* `supervisor_total_unhealthy_stacks`: The total number of unhealthy stacks. (gauge)
* `supervisor_jobs_execution_time`: The time taken to execute stack jobs, measured in seconds. (histogram)
* `supervisor_jobs_executed_total`: The total number of stack jobs executed. (counter)
* `supervisor_jobs_succeeded_total`: The total number of stack jobs that succeeded. (counter)
* `supervisor_jobs_failed_total`: The total number of stack jobs that failed. (counter)## Dashboard
Supervisor provides a simple dashboard to view and monitor stacks. The
dashboard is accessible at the URL path `/dashboard` of the Supervisor service.
The access is restricted by basic authentication. The credentials are set
via the environment variables `SUPERVISOR_DASHBOARD_USERNAME` and
`SUPERVISOR_DASHBOARD_PASSWORD`. The default credentials username is
`supervisor` and the password is `supervisor` as well.![Dashboard view](.screenshots/supervisor-dashboard.jpg "Dashboard view")
## License
Supervisor is released under the [MIT License](https://opensource.org/licenses/MIT).
## Is it any good?
[Yes.](https://news.ycombinator.com/item?id=3067434)