initial commit
This commit is contained in:
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
|
||||||
|
letsencrypt/
|
||||||
48
rma-metrics/docker-compose.yml
Normal file
48
rma-metrics/docker-compose.yml
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
services:
|
||||||
|
prometheus:
|
||||||
|
image: docker.io/prom/prometheus:v3.2.1
|
||||||
|
container_name: prometheus
|
||||||
|
command: "--config.file=/etc/prometheus/prometheus.yaml"
|
||||||
|
volumes:
|
||||||
|
- ./prometheus-config:/etc/prometheus
|
||||||
|
- prometheus-data:/prometheus
|
||||||
|
restart: unless-stopped
|
||||||
|
networks:
|
||||||
|
- proxy
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.docker.network=proxy"
|
||||||
|
- "traefik.http.routers.prometheus.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.prometheus.rule=Host(`prometheus.manager.remote-master.cloud`)"
|
||||||
|
- "traefik.http.services.prometheus.loadbalancer.server.port=9090"
|
||||||
|
- "traefik.http.routers.prometheus.service=prometheus"
|
||||||
|
- "traefik.http.routers.prometheus.tls.certresolver=myresolver"
|
||||||
|
|
||||||
|
grafana:
|
||||||
|
image: docker.io/grafana/grafana-oss:11.6.0
|
||||||
|
container_name: grafana
|
||||||
|
volumes:
|
||||||
|
- grafana-data:/var/lib/grafana
|
||||||
|
restart: unless-stopped
|
||||||
|
networks:
|
||||||
|
- proxy
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.docker.network=proxy"
|
||||||
|
- "traefik.http.routers.grafana.entrypoints=websecure"
|
||||||
|
- "traefik.http.routers.grafana.rule=Host(`metrics.manager.remote-master.cloud`)"
|
||||||
|
- "traefik.http.services.grafana.loadbalancer.server.port=3000"
|
||||||
|
- "traefik.http.routers.grafana.service=grafana"
|
||||||
|
- "traefik.http.routers.grafana.tls.certresolver=myresolver"
|
||||||
|
|
||||||
|
networks:
|
||||||
|
proxy:
|
||||||
|
external: true
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
prometheus-data:
|
||||||
|
name: prometheus-data
|
||||||
|
external: true
|
||||||
|
grafana-data:
|
||||||
|
name: grafana-data
|
||||||
|
external: true
|
||||||
34
traefik/docker-compose.yml
Normal file
34
traefik/docker-compose.yml
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
services:
|
||||||
|
traefik:
|
||||||
|
image: traefik:v3.2.1 # Use the latest stable version
|
||||||
|
restart: unless-stopped
|
||||||
|
command:
|
||||||
|
# Enable Docker Provider (listens to labels on other containers)
|
||||||
|
- --providers.docker=true
|
||||||
|
- --providers.docker.exposedbydefault=false
|
||||||
|
# Entrypoints for web traffic (HTTP and HTTPS)
|
||||||
|
- --entrypoints.web.address=:80
|
||||||
|
- --entrypoints.websecure.address=:443
|
||||||
|
|
||||||
|
- --entrypoints.websecure.http.tls.certresolver=myresolver
|
||||||
|
- --certificatesresolvers.myresolver.acme.email=development@safetytest.eu
|
||||||
|
- --certificatesresolvers.myresolver.acme.tlschallenge=true
|
||||||
|
- --certificatesresolvers.myresolver.acme.storage=/letsencrypt/acme.json
|
||||||
|
|
||||||
|
# Optional: Redirect HTTP to HTTPS
|
||||||
|
- --entrypoints.web.http.redirections.entrypoint.to=websecure
|
||||||
|
- --entrypoints.web.http.redirections.entrypoint.scheme=https
|
||||||
|
ports:
|
||||||
|
- "80:80"
|
||||||
|
- "443:443"
|
||||||
|
# Optionally, a separate port for non-HTTP/S TCP traffic if needed
|
||||||
|
# - "444:444"
|
||||||
|
volumes:
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
||||||
|
- ./letsencrypt:/letsencrypt # Volume to store certificates
|
||||||
|
networks:
|
||||||
|
- proxy # Use a common network
|
||||||
|
|
||||||
|
networks:
|
||||||
|
proxy:
|
||||||
|
external: true # Assumes you created this network beforehand
|
||||||
Reference in New Issue
Block a user