Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pli01/scalingo-traefik-buildpack
scalingo traefik buildpack
https://github.com/pli01/scalingo-traefik-buildpack
buildpacks scalingo traefik
Last synced: about 2 months ago
JSON representation
scalingo traefik buildpack
- Host: GitHub
- URL: https://github.com/pli01/scalingo-traefik-buildpack
- Owner: pli01
- Created: 2022-01-11T22:10:04.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-01-14T15:49:08.000Z (almost 3 years ago)
- Last Synced: 2024-08-04T03:03:00.557Z (5 months ago)
- Topics: buildpacks, scalingo, traefik
- Language: Shell
- Homepage:
- Size: 5.86 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-scalingo - Github
README
# Scalingo Traefik Buildpack
This buildpack aims at deploying a traefik instance on the Scalingo PaaS platform.
# Traefik
![traefik](https://doc.traefik.io/traefik/assets/img/traefik-architecture.png)
[Traefik](https://github.com/traefik/traefik) is modern HTTP reverse proxy and load balancer that makes deploying microservices easy.
# Buildpack
This buildpack is inspired from [heroku-buildpack-traefik](https://github.com/banzera/heroku-buildpack-traefik.git)
This buildpack does the following (see `bin/compile` for details):
- install traefik (select `TRAEFIK_VERSION`, default is `2.5.6`)
- start `run.sh` script at boot time# Usage
To deploy a *traefik* instance app on scalingo:
- define `BUILDPACK_URL=url_to_this_buildpack` or in .buildpacks file
- define `TRAEFIK_var` according to [traefik documentation][0]
``` bash
# sample
TRAEFIK_LOG=true
TRAEFIK_LOG_LEVEL=INFO # DEBUG
TRAEFIK_ACCESSLOG=true
TRAEFIK_ENTRYPOINTS_web_FORWARDEDHEADERS_TRUSTEDIPS=10.0.0.0/8 # to trust scalingo LB and Forward X-Forwarded- to backend
# To enable traefik dashboard / api (warning: please use auth middleware to protect the path)
TRAEFIK_API=true
TRAEFIK_API_DASHBOARD=true
TRAEFIK_API_DEBUG=false
TRAEFIK_API_INSECURE=true
```- Then, define a `provider` for dynamic configuration discovery (route, middleware,backend services), and traefik do the rest .
- Option 1 (default): define a static file or dynamic provider file[file provider documentation][1]: default is `config/dynamic.yml`, in your custom app repository
- The file can be a static file or dynamic file with (go templating variable), see example in `config/dynamic.yml.sample`
- You can define another location with `TRAEFIK_PROVIDERS_FILE_FILENAME=/app/config/mycustom.yml`- Option 2: Or define Redis provider [redis provider documentation][2]: add a `redis addons`, and configure `TRAEFIK_PROVIDERS_REDIS_` variables, and store as KV your config in redis.
- Option 3: Or define HTTP provider [HTTP provider documentation][3]: configure `TRAEFIK_PROVIDERS_HTTP_` variables, and provide your dynamic configuration via an HTTP endpoint.
- `TRAEFIK_PROVIDERS_HTTP_ENDPOINT=https://api.my-conf.domain/config/simple-conf.json`[0]: https://doc.traefik.io/traefik/reference/static-configuration/env/
[1]: https://doc.traefik.io/traefik/providers/file/
[2]: https://doc.traefik.io/traefik/providers/redis/
[3]: https://doc.traefik.io/traefik/providers/http/