blob: c1f5ae217481413945673a05ce3e4e4571c60a72 (
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
 | How to monitor Synapse metrics using Prometheus
===============================================
1: Install prometheus:
  Follow instructions at http://prometheus.io/docs/introduction/install/
2: Enable synapse metrics:
  Simply setting a (local) port number will enable it. Pick a port.
  prometheus itself defaults to 9090, so starting just above that for
  locally monitored services seems reasonable. E.g. 9092:
  Add to homeserver.yaml
    metrics_port: 9092
  Restart synapse
3: Check out synapse-prometheus-config
  https://github.com/matrix-org/synapse-prometheus-config
4: Add ``synapse.html`` and ``synapse.rules``
  The ``.html`` file needs to appear in prometheus's ``consoles`` directory,
  and the ``.rules`` file needs to be invoked somewhere in the main config
  file. A symlink to each from the git checkout into the prometheus directory
  might be easiest to ensure ``git pull`` keeps it updated.
5: Add a prometheus target for synapse
  This is easiest if prometheus runs on the same machine as synapse, as it can
  then just use localhost::
    global: {
      rule_file: "synapse.rules"
    }
    job: {
      name: "synapse"
      target_group: {
        target: "http://localhost:9092/"
      }
    }
6: Start prometheus::
   ./prometheus -config.file=prometheus.conf
7: Wait a few seconds for it to start and perform the first scrape,
   then visit the console:
    http://server-where-prometheus-runs:9090/consoles/synapse.html
 |