mirror of
https://github.com/openziti/zrok.git
synced 2025-01-25 15:28:54 +01:00
215 lines
8.0 KiB
YAML
215 lines
8.0 KiB
YAML
# this compose file is designed to merge with the ziti all-in-one quickstart compose file by renaming
|
|
# https://get.openziti.io/dock/all-in-one/compose.yml to compose.override.yml
|
|
|
|
services:
|
|
ziti-quickstart:
|
|
image: ${ZITI_CLI_IMAGE:-docker.io/openziti/ziti-cli}:${ZITI_CLI_TAG:-latest}
|
|
profiles:
|
|
- ziti
|
|
restart: unless-stopped
|
|
networks:
|
|
zrok-instance:
|
|
# this allows other containers to use the same external DNS name to reach the quickstart container from within the
|
|
# Docker network that clients outside the Docker network use to reach the quickstart container via port forwarding
|
|
aliases:
|
|
- ${ZITI_CTRL_ADVERTISED_ADDRESS:-ziti-controller}
|
|
- ${ZITI_ROUTER_ADVERTISED_ADDRESS:-ziti-router}
|
|
entrypoint:
|
|
- bash
|
|
- -euc
|
|
- |
|
|
ZITI_CMD+=" --ctrl-address ${ZITI_CTRL_ADVERTISED_ADDRESS:-ziti-quickstart}"\
|
|
" --ctrl-port ${ZITI_CTRL_ADVERTISED_PORT:-1280}"\
|
|
" --router-address ${ZITI_ROUTER_ADVERTISED_ADDRESS:-${ZITI_CTRL_ADVERTISED_ADDRESS:-ziti-quickstart}}"\
|
|
" --router-port ${ZITI_ROUTER_PORT:-3022}"\
|
|
" --password ${ZITI_PWD:-admin}"
|
|
echo "DEBUG: run command is: ziti $${@} $${ZITI_CMD}"
|
|
exec ziti "$${@}" $${ZITI_CMD}
|
|
command: -- edge quickstart --home /home/ziggy/quickstart
|
|
user: ${ZIGGY_UID:-1000}
|
|
environment:
|
|
HOME: /home/ziggy
|
|
PFXLOG_NO_JSON: "${PFXLOG_NO_JSON:-true}"
|
|
ZITI_ROUTER_NAME: ${ZITI_ROUTER_NAME:-quickstart-router}
|
|
volumes:
|
|
# store the quickstart state in a named volume "ziti_home" or store the quickstart state on the Docker host in a
|
|
# directory, ZITI_HOME
|
|
- ${ZITI_HOME:-ziti_home}:/home/ziggy
|
|
ports:
|
|
- ${ZITI_INTERFACE:-0.0.0.0}:${ZITI_CTRL_ADVERTISED_PORT:-1280}:${ZITI_CTRL_ADVERTISED_PORT:-1280}
|
|
- ${ZITI_INTERFACE:-0.0.0.0}:${ZITI_ROUTER_PORT:-3022}:${ZITI_ROUTER_PORT:-3022}
|
|
expose:
|
|
- ${ZITI_CTRL_ADVERTISED_PORT:-1280}
|
|
- ${ZITI_ROUTER_PORT:-3022}
|
|
depends_on:
|
|
ziti-quickstart-init:
|
|
condition: service_completed_successfully
|
|
healthcheck:
|
|
test:
|
|
- CMD
|
|
- ziti
|
|
- agent
|
|
- stats
|
|
interval: 3s
|
|
timeout: 3s
|
|
retries: 5
|
|
start_period: 30s
|
|
|
|
# this service is used to initialize the ziti_home volume by setting the owner to the UID of the user running the
|
|
# quickstart container
|
|
ziti-quickstart-init:
|
|
image: busybox
|
|
command: chown -Rc ${ZIGGY_UID:-1000} /home/ziggy
|
|
user: root
|
|
environment:
|
|
HOME: /home/ziggy
|
|
volumes:
|
|
# store the quickstart state in a named volume "ziti_home" or store the quickstart state on the Docker host in a
|
|
# directory, ZITI_HOME
|
|
- ${ZITI_HOME:-ziti_home}:/home/ziggy
|
|
|
|
# add a health check for the quickstart network
|
|
ziti-quickstart-check:
|
|
image: busybox
|
|
profiles:
|
|
- ziti
|
|
command: echo "Ziti is cooking"
|
|
depends_on:
|
|
ziti-quickstart:
|
|
condition: service_healthy
|
|
|
|
zrok-permissions:
|
|
profiles:
|
|
- zrok
|
|
image: busybox
|
|
command:
|
|
- /bin/sh
|
|
- -euxc
|
|
- |
|
|
chown -Rc ${ZIGGY_UID:-2171} /var/lib/zrok-*;
|
|
chmod -Rc ug=rwX,o-rwx /var/lib/zrok-*;
|
|
volumes:
|
|
- zrok_ctrl:/var/lib/zrok-controller
|
|
- zrok_frontend:/var/lib/zrok-frontend
|
|
|
|
zrok-controller:
|
|
profiles:
|
|
- zrok
|
|
depends_on:
|
|
zrok-permissions:
|
|
condition: service_completed_successfully
|
|
build:
|
|
context: .
|
|
dockerfile: ./zrok-controller.Dockerfile
|
|
args:
|
|
ZROK_CLI_IMAGE: ${ZROK_CLI_IMAGE:-openziti/zrok}
|
|
ZROK_CLI_TAG: ${ZROK_CLI_TAG:-latest}
|
|
ZROK_DNS_ZONE: ${ZROK_DNS_ZONE} # e.g., "example.com" or "127.0.0.1.sslip.io"
|
|
ZITI_CTRL_ADVERTISED_PORT: ${ZITI_CTRL_ADVERTISED_PORT:-1280}
|
|
ZROK_ADMIN_TOKEN: ${ZROK_ADMIN_TOKEN} # zrok controller admin password
|
|
ZROK_CTRL_PORT: ${ZROK_CTRL_PORT:-18080}
|
|
ZITI_PWD: ${ZITI_PWD} # ziti controller admin password
|
|
user: ${ZIGGY_UID:-2171}
|
|
command: zrok controller /etc/zrok-controller/config.yml --verbose
|
|
volumes:
|
|
- zrok_ctrl:/var/lib/zrok-controller
|
|
networks:
|
|
zrok-instance:
|
|
aliases:
|
|
- zrok.${ZROK_DNS_ZONE}
|
|
restart: unless-stopped
|
|
expose:
|
|
- ${ZROK_CTRL_PORT:-18080} # (not published)
|
|
# Caddy's published ports provide a TLS reverse proxy for the zrok controller
|
|
# ports:
|
|
# - 127.0.0.1:${ZROK_CTRL_PORT:-18080}:${ZROK_CTRL_PORT:-18080}
|
|
environment:
|
|
ZROK_USER_PWD: ${ZROK_USER_PWD} # admin account password (initial user account)
|
|
CADDY_ACME_EMAIL: ${CADDY_ACME_EMAIL} # login email address (initial user account)
|
|
|
|
zrok-frontend:
|
|
profiles:
|
|
- zrok
|
|
depends_on:
|
|
zrok-permissions:
|
|
condition: service_completed_successfully
|
|
build:
|
|
context: .
|
|
dockerfile: zrok-frontend.Dockerfile
|
|
args:
|
|
ZROK_CLI_IMAGE: ${ZROK_CLI_IMAGE:-openziti/zrok}
|
|
ZROK_CLI_TAG: ${ZROK_CLI_TAG:-latest}
|
|
ZROK_DNS_ZONE: ${ZROK_DNS_ZONE} # e.g., "example.com" or "127.0.0.1.sslip.io"
|
|
ZROK_FRONTEND_PORT: ${ZROK_FRONTEND_PORT:-8080}
|
|
ZROK_OAUTH_PORT: ${ZROK_OAUTH_PORT:-8081}
|
|
ZROK_OAUTH_HASH_KEY: ${ZROK_OAUTH_HASH_KEY-noop}
|
|
ZROK_OAUTH_GOOGLE_CLIENT_ID: ${ZROK_OAUTH_GOOGLE_CLIENT_ID:-noop}
|
|
ZROK_OAUTH_GOOGLE_CLIENT_SECRET: ${ZROK_OAUTH_GOOGLE_CLIENT_SECRET:-noop}
|
|
ZROK_OAUTH_GITHUB_CLIENT_ID: ${ZROK_OAUTH_GITHUB_CLIENT_ID:-noop}
|
|
ZROK_OAUTH_GITHUB_CLIENT_SECRET: ${ZROK_OAUTH_GITHUB_CLIENT_SECRET:-noop}
|
|
user: ${ZIGGY_UID:-2171}
|
|
command: zrok access public /etc/zrok-frontend/config.yml --verbose
|
|
volumes:
|
|
- zrok_frontend:/var/lib/zrok-frontend
|
|
networks:
|
|
zrok-instance:
|
|
restart: unless-stopped
|
|
expose:
|
|
- ${ZROK_FRONTEND_PORT:-8080} # (not published)
|
|
- ${ZROK_OAUTH_PORT:-8081} # (not published)
|
|
# ports:
|
|
# - 127.0.0.1:${ZROK_FRONTEND_PORT:-8080}:${ZROK_FRONTEND_PORT:-8080}
|
|
# - 127.0.0.1:${ZROK_OAUTH_PORT:-8081}:${ZROK_OAUTH_PORT:-8081}
|
|
environment:
|
|
HOME: /var/lib/zrok-frontend
|
|
ZROK_DNS_ZONE: ${ZROK_DNS_ZONE} # e.g., "example.com" or "127.0.0.1.sslip.io"
|
|
ZROK_ADMIN_TOKEN: ${ZROK_ADMIN_TOKEN} # zrok controller admin password
|
|
ZROK_API_ENDPOINT: http://zrok-controller:${ZROK_CTRL_PORT:-18080} # bridge address of the zrok controller
|
|
ZITI_CTRL_ADVERTISED_PORT: ${ZITI_CTRL_ADVERTISED_PORT:-1280}
|
|
ZITI_PWD: ${ZITI_PWD} # ziti controller admin password
|
|
|
|
caddy:
|
|
profiles:
|
|
- zrok
|
|
build:
|
|
context: .
|
|
dockerfile: ./caddy.Dockerfile
|
|
args:
|
|
CADDY_DNS_PLUGIN: ${CADDY_DNS_PLUGIN} # e.g., "digitalocean" (see github.com/caddy-dns)
|
|
restart: unless-stopped
|
|
environment:
|
|
CADDY_DNS_PLUGIN: ${CADDY_DNS_PLUGIN} # e.g., "digitalocean" (see github.com/caddy-dns)
|
|
CADDY_DNS_PLUGIN_TOKEN: ${CADDY_DNS_PLUGIN_TOKEN} # API token from DNS provider used by plugin to solve the ACME challenge
|
|
CADDY_ACME_EMAIL: ${CADDY_ACME_EMAIL} # email address sent to CA for ACME account and renewal notifications
|
|
CADDY_ACME_API: ${CADDY_ACME_API:-https://acme-v02.api.letsencrypt.org/directory} # ACME API endpoint
|
|
ZROK_DNS_ZONE: ${ZROK_DNS_ZONE} # e.g., "example.com" or "127.0.0.1.sslip.io"
|
|
ZROK_CTRL_PORT: ${ZROK_CTRL_PORT:-18080}
|
|
ZROK_FRONTEND_PORT: ${ZROK_FRONTEND_PORT:-8080}
|
|
ZROK_OAUTH_PORT: ${ZROK_OAUTH_PORT:-8081}
|
|
expose:
|
|
- 80/tcp
|
|
- 443/tcp
|
|
- 443/udp # Caddy's HTTP/3 (QUIC) (not published)
|
|
- 2019/tcp # Caddy's admin API (not published)
|
|
ports:
|
|
- ${CADDY_INTERFACE:-0.0.0.0}:80:80
|
|
- ${CADDY_INTERFACE:-0.0.0.0}:443:443
|
|
# - ${CADDY_INTERFACE:-0.0.0.0}:443:443/udp" # future: HTTP/3 (QUIC)
|
|
volumes:
|
|
- caddy_data:/data
|
|
- caddy_config:/config
|
|
networks:
|
|
zrok-instance:
|
|
|
|
volumes:
|
|
ziti_home: # this will not be used if you switch from named volume to bind mount volume
|
|
zrok_ctrl:
|
|
zrok_frontend:
|
|
caddy_data:
|
|
caddy_config:
|
|
|
|
# define a custom network so that we can also define DNS aliases
|
|
networks:
|
|
zrok-instance:
|
|
driver: bridge
|