Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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:

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)