2024-08-25 00:30:43 -05:00
|
|
|
{ config, pkgs, ... }:
|
2024-11-11 23:13:24 -06:00
|
|
|
let
|
|
|
|
pg_dataDir_base = "/var/lib/postgresql";
|
|
|
|
in
|
2024-05-03 14:35:00 -05:00
|
|
|
{
|
|
|
|
services.postgresqlBackup = {
|
2024-11-11 23:13:24 -06:00
|
|
|
enable = true;
|
2024-05-03 14:35:00 -05:00
|
|
|
location = "/var/backup/postgresql";
|
|
|
|
backupAll = true;
|
|
|
|
};
|
2024-11-11 23:13:24 -06:00
|
|
|
|
2024-05-03 14:35:00 -05:00
|
|
|
services.postgresql = {
|
|
|
|
enable = true;
|
2024-11-11 23:13:24 -06:00
|
|
|
dataDir = "${pg_dataDir_base}/${config.services.postgresql.package.psqlSchema}";
|
2024-05-03 14:35:00 -05:00
|
|
|
settings = {
|
|
|
|
log_connections = true;
|
|
|
|
log_disconnections = true;
|
|
|
|
logging_collector = true;
|
|
|
|
log_statement = "all";
|
|
|
|
};
|
|
|
|
ensureUsers = [
|
|
|
|
{
|
|
|
|
name = "root";
|
|
|
|
ensureClauses.superuser = true;
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
|
|
|
environment.systemPackages = [ pkgs.pgloader ];
|
|
|
|
|
|
|
|
environment.persistence.save.directories = [
|
|
|
|
{
|
2024-11-11 23:13:24 -06:00
|
|
|
directory = "${pg_dataDir_base}";
|
2024-05-03 14:35:00 -05:00
|
|
|
user = "postgres";
|
|
|
|
group = "postgres";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
directory = config.services.postgresqlBackup.location;
|
|
|
|
user = "postgres";
|
|
|
|
group = "postgres";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|