nixos-config/modules/postgresql.nix

46 lines
964 B
Nix
Raw Normal View History

{ pkgs, config, ... }:
2021-11-23 11:17:26 +01:00
{
services.postgresql = {
enable = true;
package = pkgs.postgresql_14;
enableTCPIP = true;
2022-08-03 11:14:15 +02:00
ensureUsers = [
{
name = "zbx_monitor";
ensurePermissions = {
"FUNCTION pg_catalog.pg_ls_dir(text)" = "EXECUTE";
"FUNCTION pg_catalog.pg_stat_file(text)" = "EXECUTE";
"FUNCTION pg_catalog.pg_ls_waldir()" = "EXECUTE";
};
}
];
2021-11-23 11:17:26 +01:00
};
services.postgresqlBackup = {
enable = true;
startAt = "*-*-* *:30:00";
compression = "zstd";
databases = [
"postgres"
];
};
services.logrotate = {
paths.postgresqlBackup = {
path = "${config.services.postgresqlBackup.location}/*.sql.zstd";
user = "postgres";
group = "postgres";
keep = 24;
frequency = "hourly";
extraConfig = ''
dateext
dateformat _%Y-%m-%d:%H
extension = .zstd
'';
};
};
2021-11-23 11:17:26 +01:00
}
# vim: set et ts=2 sw=2 ai: