setup grafana db
This commit is contained in:
parent
5d70cf127d
commit
f35facbcef
7 changed files with 63 additions and 27 deletions
12
flake.nix
12
flake.nix
|
|
@ -134,6 +134,12 @@
|
||||||
owner = "grafana";
|
owner = "grafana";
|
||||||
group = "grafana";
|
group = "grafana";
|
||||||
};
|
};
|
||||||
|
postgres-grafana = {
|
||||||
|
file = ./secrets/postgres-grafana.age;
|
||||||
|
mode = "440";
|
||||||
|
owner = "grafana";
|
||||||
|
group = "grafana";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
./hosts/monitoring
|
./hosts/monitoring
|
||||||
|
|
@ -160,6 +166,12 @@
|
||||||
group = "postgres";
|
group = "postgres";
|
||||||
mode = "0400";
|
mode = "0400";
|
||||||
};
|
};
|
||||||
|
postgres-grafana = {
|
||||||
|
file = ./secrets/postgres-grafana.age;
|
||||||
|
owner = "postgres";
|
||||||
|
group = "postgres";
|
||||||
|
mode = "0400";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
./hosts/sql
|
./hosts/sql
|
||||||
|
|
|
||||||
|
|
@ -18,8 +18,9 @@
|
||||||
proxy_http_version 1.1;
|
proxy_http_version 1.1;
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
"/metrics" = {
|
"/_synapse/metrics" = {
|
||||||
return = "204 \"🔍️\"";
|
proxyPass = "http://[::1]:9009";
|
||||||
|
recommendedProxySettings = true;
|
||||||
extraConfig = ''
|
extraConfig = ''
|
||||||
allow 2001:678:760:cccb::14;
|
allow 2001:678:760:cccb::14;
|
||||||
allow 195.160.173.14;
|
allow 195.160.173.14;
|
||||||
|
|
|
||||||
|
|
@ -13,13 +13,14 @@
|
||||||
type = "postgres";
|
type = "postgres";
|
||||||
name = "grafana";
|
name = "grafana";
|
||||||
user = "grafana";
|
user = "grafana";
|
||||||
host = "/run/postgresql";
|
host = "sql.berlin.ccc.de:5432";
|
||||||
|
password = "$__file{${config.age.secrets.postgres-grafana.path}}";
|
||||||
};
|
};
|
||||||
security = {
|
security = {
|
||||||
secret_key = "$__file{${config.age.secrets.grafana_secret_key.path}}";
|
secret_key = "$__file{${config.age.secrets.grafana_secret_key.path}}";
|
||||||
admin_user = "xengi";
|
admin_user = "xengi";
|
||||||
admin_password = "$__file{${config.age.secrets.grafana_admin_password.path}}";
|
admin_password = "$__file{${config.age.secrets.grafana_admin_password.path}}";
|
||||||
admin_email = "grafana@xengi.de";
|
admin_email = "cccb-grafana@xengi.de";
|
||||||
};
|
};
|
||||||
analytics = {
|
analytics = {
|
||||||
reporting_enabled = false;
|
reporting_enabled = false;
|
||||||
|
|
@ -42,17 +43,6 @@
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
postgresql = {
|
|
||||||
ensureUsers = [
|
|
||||||
{
|
|
||||||
name = config.services.grafana.settings.database.user;
|
|
||||||
ensureDBOwnership = true;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
ensureDatabases = [
|
|
||||||
config.services.grafana.settings.database.name
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -20,30 +20,41 @@
|
||||||
{
|
{
|
||||||
job_name = "synapse";
|
job_name = "synapse";
|
||||||
scrape_interval = "15s";
|
scrape_interval = "15s";
|
||||||
static_configs = [
|
metrics_path = "/_synapse/metrics";
|
||||||
{
|
static_configs = [{ targets = [ "matrix.berlin.ccc.de:443" ]; }];
|
||||||
targets = lib.pipe config.services.matrix-synapse.settings.listeners [
|
|
||||||
(lib.filter (l: l.type == "metrics"))
|
|
||||||
builtins.head
|
|
||||||
(l: [ "[${builtins.head l.bind_addresses}]:${toString l.port}" ])
|
|
||||||
];
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
job_name = "node";
|
job_name = "node";
|
||||||
scrape_interval = "15s";
|
scrape_interval = "15s";
|
||||||
static_configs = [
|
static_configs = [
|
||||||
{ targets = [ "${config.services.prometheus.exporters.node.listenAddress}:${toString config.services.prometheus.exporters.node.port}" ]; }
|
{
|
||||||
|
targets = [
|
||||||
|
"matrix.berlin.ccc.de:${toString config.services.prometheus.exporters.node.port}"
|
||||||
|
"md.berlin.ccc.de:${toString config.services.prometheus.exporters.node.port}"
|
||||||
|
"sql.berlin.ccc.de:${toString config.services.prometheus.exporters.node.port}"
|
||||||
|
"${config.services.prometheus.exporters.node.listenAddress}:${toString config.services.prometheus.exporters.node.port}"
|
||||||
|
];
|
||||||
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
job_name = "nginx";
|
job_name = "nginx";
|
||||||
scrape_interval = "15s";
|
scrape_interval = "15s";
|
||||||
static_configs = [
|
static_configs = [
|
||||||
{ targets = [ "${config.services.prometheus.exporters.nginx.listenAddress}:${toString config.services.prometheus.exporters.nginx.port}" ]; }
|
{
|
||||||
|
targets = [
|
||||||
|
"matrix.berlin.ccc.de:${toString config.services.prometheus.exporters.nginx.port}"
|
||||||
|
"md.berlin.ccc.de:${toString config.services.prometheus.exporters.nginx.port}"
|
||||||
|
"${config.services.prometheus.exporters.nginx.listenAddress}:${toString config.services.prometheus.exporters.nginx.port}"
|
||||||
|
];
|
||||||
|
}
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
{
|
||||||
|
job_name = "postgres";
|
||||||
|
scrape_interval = "15s";
|
||||||
|
static_configs = [{ targets = [ "sql.berlin.ccc.de:${config.services.prometheus.exporters.postgres.port}" ]; }];
|
||||||
|
}
|
||||||
];
|
];
|
||||||
ruleFiles = [
|
ruleFiles = [
|
||||||
# https://github.com/element-hq/synapse/tree/master/contrib/prometheus
|
# https://github.com/element-hq/synapse/tree/master/contrib/prometheus
|
||||||
|
|
@ -7,6 +7,7 @@ let
|
||||||
entries = [
|
entries = [
|
||||||
(mkEntry "matrix-synapse" 25) # matrix.berlin.ccc.de
|
(mkEntry "matrix-synapse" 25) # matrix.berlin.ccc.de
|
||||||
(mkEntry "hedgedoc" 26) # md.berlin.ccc.de
|
(mkEntry "hedgedoc" 26) # md.berlin.ccc.de
|
||||||
|
(MkEntry "grafana" 14) # monitoring.berlin.ccc.de
|
||||||
];
|
];
|
||||||
mkEntry = name: octet: {
|
mkEntry = name: octet: {
|
||||||
user = {
|
user = {
|
||||||
|
|
|
||||||
20
secrets/postgres-grafana.age
Normal file
20
secrets/postgres-grafana.age
Normal file
|
|
@ -0,0 +1,20 @@
|
||||||
|
age-encryption.org/v1
|
||||||
|
-> ssh-ed25519 uH+n1w DYVhwEzWwZyr3IH7Cl2qa0g2Zg7Yrmeyn0Pf+Gqt7HU
|
||||||
|
kDQGApNi5sfgIWXdW4LH6Kzy2mrvFN8yk5uWUYT4oXY
|
||||||
|
-> ssh-ed25519 EvLbWw K/A2Gy0eVr1u+44r4XsHV2N6lmUHIu8cV+g3IkjHe0M
|
||||||
|
HiMAzVd2NV7bbi20J+VEjsiyaevm7iEtec4igRA2ySQ
|
||||||
|
-> ssh-ed25519 dM+fLQ 5F6iAC+GHRsF489WhDjjkLgcnOr+ywU3sWtoYuYMZyg
|
||||||
|
C8by0wcMpQwZmI4FaNkNc6rpzAKZPrzS7cm+CwFl3Rw
|
||||||
|
-> ssh-ed25519 jxWM2Q idZ3x0aaYoH71CgL6NQ1qDf233yXkH9oNZhwzasgOxc
|
||||||
|
ED0t4oArzmVAIS5+KU6cCENnEUO4kuwBNhuMYl183vE
|
||||||
|
-> ssh-ed25519 /yCUCg 98BSIjgr6S+QHlbZ8SP+PFBePaCXel+2n+rCLAITU38
|
||||||
|
HSum+YkvuOhZZKJfgJ/KO2cTi04r/JuBXbSk9CD0jFs
|
||||||
|
-> ssh-ed25519 FGp51g CvBv6/QnajCnWLJb4VXA7KE6jQ/1VrUZWlwvQDcGWn0
|
||||||
|
WEKU5CrdH/ZuTj1MYgeoX/oM7qqYqa3kbCi2AIKvQJQ
|
||||||
|
-> ssh-ed25519 I2FcBQ 3msOE4meBfv7DgSAAgbuVIYQM6VrR666P6Ay1GfAtm0
|
||||||
|
N0/JVT/IOTNamPfjVuUbb8H/vYMXsdAViiKWMHapu1M
|
||||||
|
-> ssh-ed25519 Iapucg y2M94CuOpTskf5aHoqewoMwtjJ/+XUdojaTY5A+RAl8
|
||||||
|
9oG5ux0F/Y1hz4ZMZvHvvgcopOJ3SRVg4RRCZeT+RDQ
|
||||||
|
--- AGVfxKHT0uVsWIFMvRHrAQwBiCzke/xWNb6pg6mxlVE
|
||||||
|
ךv_<76>ñ<EFBFBD>L›ŠÜ|Ù"ý󰀎.$EEuAÂÝÊKÞ7´J‚›¹øýæó+Ñ[ظ×å<cö½ê©®)ªÛe¥-@—ÜÒ§@]c¬íóüñ0«Ý<C2AB>¡€äÔU͹Þ
|
||||||
|
Ël±R‚
|
||||||
|
|
@ -38,6 +38,7 @@ in
|
||||||
|
|
||||||
"postgres-matrix-synapse.age".publicKeys = users ++ [ _sql _matrix ];
|
"postgres-matrix-synapse.age".publicKeys = users ++ [ _sql _matrix ];
|
||||||
"postgres-hedgedoc.age".publicKeys = users ++ [ _sql _md ];
|
"postgres-hedgedoc.age".publicKeys = users ++ [ _sql _md ];
|
||||||
|
"postgres-grafana.age".publicKeys = users ++ [ _sql _monitoring ];
|
||||||
|
|
||||||
"www-staging-htpasswd.age".publicKeys = users ++ [ _www ];
|
"www-staging-htpasswd.age".publicKeys = users ++ [ _www ];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue