aboutsummaryrefslogtreecommitdiff
path: root/app/telemetry/deploy/telemetry.hcl
blob: c3edd4c66c9a918f37c9ddd90d66742482584335 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
job "telemetry" {
  datacenters = ["neptune"]
  type = "service"

  group "kibana" {
    count = 1

    network {
      port "kibana" {
        static = 5601
      }
    }

    task "kibana" {
      driver = "docker"
      config {
        image = "docker.elastic.co/kibana/kibana:7.17.0"
        network_mode = "host"
        ports = [ "kibana" ]
      }

      template {
        data = <<EOH
SERVER_NAME=kibana.local
ELASTICSEARCH_HOSTS=http://localhost:9200
ELASTICSEARCH_USERNAME=kibana_system
ELASTICSEARCH_PASSWORD={{ key "secrets/telemetry/elastic_passwords/kibana_system" }}
EOH
        destination = "secrets/env"
        env = true
      }

      resources {
        memory = 1500
        cpu = 500
      }

      service {
        tags = [
            "kibana",
            "tricot kibana.home.adnab.me",
        ]
        port = 5601
        address_mode = "driver"
        name = "kibana"
        check {
          type = "tcp"
          port = 5601
          address_mode = "driver"
          interval = "60s"
          timeout = "5s"
          check_restart {
            limit = 3
            grace = "90s"
            ignore_warnings = false
          }
        }
      }
    }
  }
  
  group "grafana" {
    count = 1

    constraint {
      attribute = "${attr.unique.hostname}"
      operator = "="
      value = "carcajou"
    }

    network {
      port "grafana" {
        static = 3333
      }
    }

    task "grafana" {
      driver = "docker"
      config {
        image = "grafana/grafana:8.3.5"
        network_mode = "host"
        ports = [ "grafana" ]
        volumes = [
          "/mnt/ssd/telemetry/grafana:/var/lib/grafana",
          "secrets/elastic.yaml:/etc/grafana/provisioning/datasources/elastic.yaml"
        ]
      }

      template {
        data = file("../config/grafana/provisioning/datasources/elastic.yaml")
        destination = "secrets/elastic.yaml"
      }

      template {
        data = <<EOH
GF_INSTALL_PLUGINS=grafana-clock-panel,grafana-simple-json-datasource,grafana-piechart-panel,grafana-worldmap-panel,grafana-polystat-panel
GF_SERVER_HTTP_PORT=3333
EOH
        destination = "secrets/env"
        env = true
      }

      resources {
        memory = 500
        cpu = 100
      }
    }

  }
}