myos/stack/node/node.yml

114 lines
4.0 KiB
YAML
Raw Normal View History

2021-02-09 17:05:00 +01:00
version: '3.6'
services:
consul:
build:
args:
2022-05-09 04:41:06 +02:00
- CONSUL_VERSION=1.11.1
2021-02-09 17:05:00 +01:00
- DOCKER_BUILD_DIR=docker/consul
context: ../..
dockerfile: docker/consul/Dockerfile
2022-07-26 21:57:34 +02:00
container_name: ${NODE_COMPOSE_PROJECT_NAME}_consul
image: ${NODE_DOCKER_REPOSITORY}/consul:${DOCKER_IMAGE_TAG}
2021-02-09 17:05:00 +01:00
environment:
CONSUL_BIND_INTERFACE: '${DOCKER_HOST_IFACE}'
CONSUL_CLIENT_INTERFACE: '${DOCKER_HOST_IFACE}'
2022-07-26 21:57:34 +02:00
CONSUL_HTTP_TOKEN: '${NODE_CONSUL_HTTP_TOKEN}'
2021-02-09 17:05:00 +01:00
CONSUL_LOCAL_CONFIG: '{ "log_level": "warn"
, "enable_script_checks": true
, "acl": { "enabled": true
, "default_policy": "deny"
2022-05-08 00:37:46 +02:00
, "down_policy": "extend-cache"
2021-02-09 17:05:00 +01:00
, "enable_token_persistence": true
2022-07-26 21:57:34 +02:00
, "tokens": { "initial_management": "${NODE_CONSUL_ACL_TOKENS_MASTER}"
, "agent": "${NODE_CONSUL_HTTP_TOKEN}"
2021-02-09 17:05:00 +01:00
}
}
}'
hostname: ${HOSTNAME}
labels:
- SERVICE_8300_IGNORE=true
- SERVICE_8301_IGNORE=true
- SERVICE_8302_IGNORE=true
2022-05-08 00:37:46 +02:00
- SERVICE_8500_CHECK_HTTP=/v1/health/service/consul
2022-07-26 21:57:34 +02:00
- SERVICE_8500_NAME=${NODE_COMPOSE_SERVICE_NAME}-consul:8500
- SERVICE_8500_TAGS=${NODE_CONSUL_SERVICE_8500_TAGS}
2021-02-09 17:05:00 +01:00
- SERVICE_8600_IGNORE=true
2022-06-30 23:37:10 +02:00
- SERVICE_ADDRESS=${DOCKER_HOST_INET4}
- SERVICE_CHECK_SCRIPT=docker-healthcheck ${DOCKER_HOST_INET4}
2021-02-09 17:05:00 +01:00
network_mode: host
restart: always
volumes:
2022-06-30 23:37:10 +02:00
- consul:/consul/data:delegated
- ssl-certs:/certs:ro
2021-02-09 17:05:00 +01:00
- /var/run/docker.sock:/var/run/docker.sock
fabio:
2022-05-09 04:41:06 +02:00
build:
args:
- DOCKER_BUILD_DIR=docker/fabio
- FABIO_VERSION=1.6.0
- OPERATING_SYSTEM=${OPERATING_SYSTEM}
- PROCESSOR_ARCHITECTURE=${PROCESSOR_ARCHITECTURE}
context: ../..
dockerfile: docker/fabio/Dockerfile
2022-07-26 21:57:34 +02:00
container_name: ${NODE_COMPOSE_PROJECT_NAME}_fabio
image: ${NODE_DOCKER_REPOSITORY}/fabio:${DOCKER_IMAGE_TAG}
command: -registry.backend "consul" -registry.consul.addr "consul:8500" -registry.consul.token "${NODE_CONSUL_HTTP_TOKEN}" -proxy.addr ":80,:443;cs=local" -proxy.cs "cs=local;type=file;cert=/certs/${DOMAIN}.crt.pem;key=/certs/${DOMAIN}.key.pem"
2021-02-09 17:05:00 +01:00
depends_on:
- consul
extra_hosts:
2022-06-30 23:37:10 +02:00
- consul:${DOCKER_INTERNAL_DOCKER_HOST}
2021-02-09 17:05:00 +01:00
hostname: ${HOSTNAME}
labels:
2022-05-09 15:33:46 +02:00
- SERVICE_80_CHECK_TCP=true
2022-07-26 21:57:34 +02:00
- SERVICE_80_NAME=${NODE_COMPOSE_SERVICE_NAME}-fabio:80
2022-05-09 15:33:46 +02:00
- SERVICE_443_CHECK_TCP=true
2022-07-26 21:57:34 +02:00
- SERVICE_443_NAME=${NODE_COMPOSE_SERVICE_NAME}-fabio:443
2022-05-08 00:37:46 +02:00
- SERVICE_9998_CHECK_HTTP=/routes
2022-07-26 21:57:34 +02:00
- SERVICE_9998_NAME=${NODE_COMPOSE_SERVICE_NAME}-fabio:9998
- SERVICE_9998_TAGS=${NODE_FABIO_SERVICE_9998_TAGS}
2021-02-09 17:05:00 +01:00
- SERVICE_9999_IGNORE=true
ports:
2022-05-08 00:37:46 +02:00
- 80:80/tcp
- 443:443/tcp
- 9998/tcp
2021-02-09 17:05:00 +01:00
networks:
- public
restart: always
volumes:
2022-06-30 23:37:10 +02:00
- ssl-certs:/certs:ro
2021-02-09 17:05:00 +01:00
registrator:
build:
args:
- DOCKER_BUILD_DIR=docker/registrator
2022-02-07 15:09:51 +01:00
- GIT_AUTHOR_NAME=${GIT_AUTHOR_NAME}
- GIT_AUTHOR_EMAIL=${GIT_AUTHOR_EMAIL}
2021-02-09 17:05:00 +01:00
context: ../..
dockerfile: docker/registrator/Dockerfile
2022-07-26 21:57:34 +02:00
container_name: ${NODE_COMPOSE_PROJECT_NAME}_registrator
image: ${NODE_DOCKER_REPOSITORY}/registrator:${DOCKER_IMAGE_TAG}
command: -internal -cleanup -deregister always -resync=30 -useIpFromNetwork "${DOCKER_NETWORK_PUBLIC}" -useIpFromLabel SERVICE_ADDRESS consul://consul:8500
2021-02-09 17:05:00 +01:00
depends_on:
- consul
environment:
2022-07-26 21:57:34 +02:00
- CONSUL_HTTP_TOKEN=${NODE_CONSUL_HTTP_TOKEN}
2021-02-09 17:05:00 +01:00
extra_hosts:
2022-06-30 23:37:10 +02:00
- consul:${DOCKER_INTERNAL_DOCKER_HOST}
2021-02-09 17:05:00 +01:00
hostname: ${HOSTNAME}
network_mode: host
restart: always
volumes:
- /var/run/docker.sock:/tmp/docker.sock
volumes:
consul:
2022-07-26 21:57:34 +02:00
name: ${NODE_COMPOSE_PROJECT_NAME}_consul
2021-02-09 17:05:00 +01:00
ssl-certs:
2022-06-30 23:37:10 +02:00
external: true
2022-07-26 21:57:34 +02:00
name: ${NODE_COMPOSE_PROJECT_NAME}_ssl-certs
2021-02-09 17:05:00 +01:00
networks:
public:
external: true
name: ${DOCKER_NETWORK_PUBLIC}