traefik/README.md

41 lines
1.8 KiB
Markdown
Raw Normal View History

2023-06-16 15:16:37 +00:00
# unhinged-traefik
The traefik ingress and service discovery component of the unhinged cluster stack. Relies on docker
## Supported Labels
| Label | Description |
| ------------------------------- | ------------------------------------------------------------------------------------------------- |
| com.keganmyers.unhinged.http | An [HttpAnnouncement](#HttpAnnouncement) |
| com.keganmyers.unhinged.http.\* | An [HttpAnnouncement](#HttpAnnouncement), used when you need more than one for a single container |
## Configuration
### HttpAnnouncement
```
{
"name": "git", // required, name of service
"rule": "Host(`git.keganmyers.com`)", // required, the host rule for the http router
"port": 3009, // required, the port for the server on the http service
"entrypoints": ["web"], // required, which entrypoints to listen on
"middlewares": ["foo", "bar@provider"], // optional, the _names_ of any middlewares to attach to this router
// todo: protocol
// todo: transport
}
```
## components
### unhinged-traefik-announcer
Finds relevant labels on containers, and announces them to a server.
This is packaged as an executable using [`pkg`](https://github.com/vercel/pkg), and intended to be run via systemd. The server to announce to is defined via the `URL` environment variable, such as `URL=ws://127.0.0.1`.
### unhinged-traefik-server
A server that listens for announcements and retractions, then generates a configuration for traefik to consume through its [HTTP configuration provider](https://doc.traefik.io/traefik/providers/http/).
This is packaged as a docker container.