version: '3.8' services: postgres: container_name: postgres image: postgres:13-alpine volumes: - db:/var/lib/postgresql/data environment: POSTGRES_DB: db POSTGRES_PASSWORD: pass ports: - '127.0.0.1:5432:5432' shm_size: 256mb restart: unless-stopped traefik: container_name: traefik image: traefik:v2.5.3 command: - "--providers.docker=true" - "--providers.docker.exposedbydefault=false" - "--entrypoints.web.address=:80" - "--entrypoints.web.http.redirections.entryPoint.to=websecure" - "--entrypoints.web.http.redirections.entryPoint.scheme=https" - "--entrypoints.websecure.address=:443" - "--certificatesresolvers.myresolver.acme.tlschallenge=true" #- "--certificatesresolvers.myresolver.acme.caserver=https://acme-staging-v02.api.letsencrypt.org/directory" - "--certificatesresolvers.myresolver.acme.email=${LETS_ENCRYPT_EMAIL}" - "--certificatesresolvers.myresolver.acme.storage=/letsencrypt/acme.json" ports: - "80:80" - "443:443" volumes: - "./letsencrypt:/letsencrypt" - "/var/run/docker.sock:/var/run/docker.sock:ro" restart: unless-stopped grafana: container_name: grafana image: grafana/grafana:8.1.5 volumes: - ./grafana/provisioning:/etc/grafana/provisioning - ./grafana/dashboards:/etc/grafana/dashboards - grafana-storage:/var/lib/grafana environment: PG_HOST: 'postgres:5432' PG_USER: 'read_user' PG_PASSWORD: 'read_user_pass' PG_DB: 'db' PROM_USER: 'admin' PROM_HOST: 'http://prometheus:9090' env_file: - .env labels: - "traefik.enable=true" - "traefik.http.routers.grafana.rule=Host(`${GRAFANA_HOST_DOMAIN}`)" - "traefik.http.routers.grafana.entrypoints=websecure" - "traefik.http.routers.grafana.tls.certresolver=myresolver" restart: unless-stopped prometheus: container_name: prometheus image: prom/prometheus:v2.30.0 volumes: - ./prometheus:/etc/prometheus - prom-storage:/prometheus command: [ "--config.file=/etc/prometheus/prometheus.yml", "--web.enable-lifecycle", "--web.config.file=/etc/prometheus/web.yml" ] labels: - "traefik.enable=true" - "traefik.http.routers.prometheus.rule=Host(`${PROMETHEUS_HOST_DOMAIN}`)" - "traefik.http.routers.prometheus.entrypoints=websecure" - "traefik.http.routers.prometheus.tls.certresolver=myresolver" restart: unless-stopped alertmanager: container_name: alertmanager image: prom/alertmanager:v0.23.0 command: [ "--config.file=/etc/prometheus/alertmanager.yml", "--storage.path=/alertmanager", "--web.external-url=https://${ALERTMANAGER_HOST_DOMAIN}", "--web.config.file=/etc/prometheus/web.yml" ] volumes: - ./prometheus:/etc/prometheus - alertmanager-storage:/alertmanager labels: - "traefik.enable=true" - "traefik.http.routers.alertmanager.rule=Host(`${ALERTMANAGER_HOST_DOMAIN}`)" - "traefik.http.routers.alertmanager.entrypoints=websecure" - "traefik.http.routers.alertmanager.tls.certresolver=myresolver" restart: unless-stopped monitor: container_name: monitor image: ghcr.io/omni/tokenbridge-monitor:v0.1.6 env_file: - .env volumes: - ./config.yml:/app/config.yml labels: - "traefik.enable=true" - "traefik.http.routers.monitor.rule=Host(`${MONITOR_HOST_DOMAIN}`)" - "traefik.http.routers.monitor.entrypoints=websecure" - "traefik.http.routers.monitor.tls.certresolver=myresolver" restart: unless-stopped fix_block_timestamps: container_name: fix_block_timestamps image: ghcr.io/omni/tokenbridge-monitor:v0.1.6 entrypoint: [ "./fix_block_timestamps" ] env_file: - .env volumes: - ./config.yml:/app/config.yml reprocess_block_range: container_name: fix_block_timestamps image: ghcr.io/omni/tokenbridge-monitor:v0.1.6 entrypoint: [ "./reprocess_block_range" ] env_file: - .env volumes: - ./config.yml:/app/config.yml volumes: db: grafana-storage: prom-storage: alertmanager-storage: