You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
125 lines
4.3 KiB
YAML
125 lines
4.3 KiB
YAML
---
|
|
|
|
service_port_grafana: 3000
|
|
service_port_prometheus: 9090
|
|
service_port_alertmanager: 9093
|
|
|
|
prometheus_id: "{{ service_name }}-prometheus"
|
|
alertmanager_id: "{{ service_name }}-alertmanager"
|
|
grafana_id: "{{ service_name }}-grafana"
|
|
|
|
prometheus_docker: {
|
|
networks: [
|
|
{
|
|
name: back-tier,
|
|
external: true,
|
|
},
|
|
{
|
|
name: front-tier,
|
|
external: true,
|
|
},
|
|
],
|
|
volumes: [
|
|
{
|
|
name: "{{ prometheus_id }}-data"
|
|
},
|
|
{
|
|
name: "{{ alertmanager_id }}-data"
|
|
},
|
|
{
|
|
name: "{{ grafana_id }}-data"
|
|
},
|
|
],
|
|
services: [
|
|
{
|
|
name: "{{ prometheus_id }}",
|
|
image_name: "{{ grafana_image_name }}",
|
|
image_version: "{{ prometheus_image_version }}",
|
|
labels: [
|
|
'"traefik.enable=true"',
|
|
'"traefik.http.routers.{{ prometheus_id }}.service={{ prometheus_id }}"',
|
|
'"traefik.http.routers.{{ prometheus_id }}.rule=Host(`{{ service_name }}-prometheus.{{ domain }}`)"',
|
|
'"traefik.http.routers.{{ prometheus_id }}.entrypoints=websecure"',
|
|
'"traefik.http.routers.{{ prometheus_id }}.tls=true"',
|
|
'"traefik.http.routers.{{ prometheus_id }}.tls.certresolver=letsencrypt"',
|
|
'"traefik.http.services.{{ prometheus_id }}.loadbalancer.server.port={{ service_port_prometheus }}"',
|
|
],
|
|
command: [
|
|
'"--config.file=/etc/prometheus/prometheus.yml"',
|
|
'"--storage.tsdb.path=/prometheus"',
|
|
'"--web.console.libraries=/usr/share/prometheus/console_libraries"',
|
|
'"--web.console.templates=/usr/share/prometheus/consoles"',
|
|
'"--web.external-url={{ http_s}}://{{ service_name }}-prometheus.{{ domain }}"',
|
|
'"--web.enable-lifecycle"',
|
|
'"--storage.tsdb.retention.time=15w"',
|
|
],
|
|
volumes: [
|
|
'"./config/prometheus/:/etc/prometheus/:ro"',
|
|
'"{{ prometheus_id }}-data:/prometheus"',
|
|
],
|
|
networks: [
|
|
'"back-tier"',
|
|
'"front-tier"',
|
|
],
|
|
extra_hosts: "{{ prometheus_extra_hosts | default([]) }}",
|
|
},
|
|
{
|
|
name: "{{ alertmanager_id }}",
|
|
image_name: "{{ alertmanager_image_name }}",
|
|
image_version: "{{ alertmanager_image_version }}",
|
|
labels: [
|
|
'"traefik.enable=true"',
|
|
'"traefik.http.routers.{{ alertmanager_id }}.service={{ alertmanager_id }}"',
|
|
'"traefik.http.routers.{{ alertmanager_id }}.rule=Host(`{{ service_name }}-alertmanager.{{ domain }}`)"',
|
|
'"traefik.http.routers.{{ alertmanager_id }}.entrypoints=websecure"',
|
|
'"traefik.http.routers.{{ alertmanager_id }}.tls=true"',
|
|
'"traefik.http.routers.{{ alertmanager_id }}.tls.certresolver=letsencrypt"',
|
|
'"traefik.http.services.{{ alertmanager_id }}.loadbalancer.server.port={{ service_port_alertmanager }}"',
|
|
],
|
|
command: [
|
|
'"--config.file=/etc/alertmanager/config.yml"',
|
|
'"--storage.path=/alertmanager"',
|
|
'"--web.external-url={{ http_s}}://{{ service_name }}-alertmanager.{{ domain }}"',
|
|
],
|
|
environment: [
|
|
'LS_JAVA_OPTS: "-Xmx1G -Xms1G"',
|
|
],
|
|
volumes: [
|
|
'"./config/alertmanager/:/etc/alertmanager/:ro"',
|
|
'"{{ alertmanager_id }}-data:/alertmanager"',
|
|
],
|
|
networks: [
|
|
'"back-tier"',
|
|
'"front-tier"',
|
|
],
|
|
},
|
|
{
|
|
name: "{{ grafana_id }}",
|
|
image_name: "{{ grafana_image_name }}",
|
|
image_version: "{{ grafana_image_version }}",
|
|
user: '"472"',
|
|
labels: [
|
|
'"traefik.enable=true"',
|
|
'"traefik.http.routers.{{ grafana_id }}.service={{ grafana_id }}"',
|
|
'"traefik.http.routers.{{ grafana_id }}.rule=Host(`{{ service_name }}-grafana.{{ domain }}`)"',
|
|
'"traefik.http.routers.{{ grafana_id }}.entrypoints=websecure"',
|
|
'"traefik.http.routers.{{ grafana_id }}.tls=true"',
|
|
'"traefik.http.routers.{{ grafana_id }}.tls.certresolver=letsencrypt"',
|
|
'"traefik.http.services.{{ grafana_id }}.loadbalancer.server.port={{ service_port_grafana }}"',
|
|
],
|
|
volumes: [
|
|
'"./config/grafana/provisioning/:/etc/grafana/provisioning/"',
|
|
'"./config/grafana/conf/defaults.ini:/usr/share/grafana/conf/defaults.ini"',
|
|
'"{{ grafana_id }}-data:/var/lib/grafana"',
|
|
],
|
|
networks: [
|
|
'"back-tier"',
|
|
'"front-tier"',
|
|
],
|
|
env_file: [
|
|
'"./config/grafana/config.monitoring"',
|
|
],
|
|
}
|
|
],
|
|
}
|