Narrative container lifecycle management for Traefik
This is a replacement for the original OpenRESTy based Lua narrative lifecycle management code. It uses the same underlying reverse proxy service that JupyterHub is moving towards ( https://blog.jupyter.org/introducing-traefikproxy-a-new-jupyterhub-proxy-based-on-traefik-4839e972faf6 )
The narrative-traefiker container must run in the same stack as the traefik instance. On startup the initialization code will examine the rancher metadata services to find the appropriate stack_id
The following environment variables should be in the startup environment:
- hostname - set to the hostname that should be in the traefik routing rules for narratives
- rancher_user - the user id used in the rancher credentials for accessing the rancher API. These credential should have create privs in the environment that traefik and narrative-traefiker are running
- rancher_password - password for rancher access
- rancher_url - endpoint for the rancher API, this service is currently written to use the "v2-beta" api
- reaper_ipnetwork - one network that is allowed to access the /reaper/ endpoint
Any config key in the cfg dictionary in app.py can be overridden by an environment variable. Some useful environment variables are:
- narrative_version_url - a URL that returns the current version of the narrative.
- image_name - the name of the image to be used to spawn narrative services in Rancher. DO NOT include a :tag in this name.
- image_tag - an optional variable to hardcode an image tag to use (omit the ':'). If not specified, defaults to whatever is returned by
narrative_version_url
. Do not define image_tag with an empty value or otherwise bad value (e.g., whitespace) or the services traefiker attempts to spin up may break. - auth2 - a valid URL to /api/V2/me
- status_role - an auth2 role that allows traefiker to return information about running narratives from the /narrative_status/ endpoint for debugging (otherwise only timestamp and traefiker version is returned)
Any environment variable with the prefix "NARRENV_" will be passed to the narrative containers when they are started, with the "NARRENV_" prefix stripped out. For example, NARRENV_testvar="test" will result in testvar="test" being set in the startup for natrratives.
The following labels need to be set to have traefik recognize this container and start routing for it:
- traefik.enable = true
- traefik.http.routers.authsvc.rule = Host("logstashanl.chicago.kbase.us") && PathPrefix("/narrative")
- traefik.http.routers.authsvc.entrypoints = web
A port has to be exposed on this container for traefik to properly route to it. Internally this service uses port 5000, recommendation is to export 5000 as well.
Normally, narrative containers will simply run indefinitely. In order to clean up inactive containers, contact the service's /reaper/ endpoint, which will remove any containers which have not had active traffic for reaper_timeout_secs
(default 600 seconds/10 minutes). Use the reaper_ipnetwork
environment variable to restrict access to one subnet (can specify 0.0.0.0/0 to disable access control).
The location for finding metrics on container activity is in the configuration "traefik_metrics" and defaults to "http://traefik:8080/metrics". This means the traefik service needs to be named "traefik" and exposing metrics on port 8080.