From 6f82f965a742d2013d9bab578a4d83fa37526902 Mon Sep 17 00:00:00 2001 From: Gregor Kleen Date: Sat, 19 Feb 2022 15:05:25 +0100 Subject: vidhar: zfssnap... --- hosts/vidhar/zfs.nix | 62 ++-------------------------------------------------- 1 file changed, 2 insertions(+), 60 deletions(-) (limited to 'hosts/vidhar') diff --git a/hosts/vidhar/zfs.nix b/hosts/vidhar/zfs.nix index f5a0383a..bee4e88a 100644 --- a/hosts/vidhar/zfs.nix +++ b/hosts/vidhar/zfs.nix @@ -1,32 +1,5 @@ { pkgs, lib, config, ... }: -let - snapshotNames = ["frequent" "hourly" "daily" "monthly" "yearly"]; - snapshotCount = { - frequent = 24; - hourly = 24; - daily = 30; - monthly = 12; - yearly = 5; - }; - snapshotTimerConfig = { - frequent = { OnCalendar = "*:0/5 UTC"; Persistent = true; }; - hourly = { OnCalendar = "hourly UTC"; Persistent = true; }; - daily = { OnCalendar = "daily UTC"; Persistent = true; }; - monthly = { OnCalendar = "monthly UTC"; Persistent = true; }; - yearly = { OnCalendar = "yearly UTC"; Persistent = true; }; - }; - snapshotDescr = { - frequent = "few minutes"; - hourly = "hour"; - daily = "day"; - monthly = "month"; - yearly = "year"; - }; - - zfs = config.boot.zfs.package; - - autosnapPackage = pkgs.zfstools.override { inherit zfs; }; -in { +{ config = { fileSystems = { "/boot" = @@ -136,38 +109,7 @@ in { echo "=== ZPOOL IMPORT COMPLETE ===" ''; - systemd.services = - let mkSnapService = snapName: { - name = "zfs-snapshot-${snapName}"; - value = { - description = "ZFS auto-snapshot every ${snapshotDescr.${snapName}}"; - after = [ "zfs-import.target" ]; - serviceConfig = { - Type = "oneshot"; - ExecStart = "${autosnapPackage}/bin/zfs-auto-snapshot -k -p -u ${snapName} ${toString snapshotCount.${snapName}}"; - }; - restartIfChanged = false; - - preStart = '' - ${zfs}/bin/zfs set com.sun:auto-snapshot=true hdd-raid6/safe - ${zfs}/bin/zfs set com.sun:auto-snapshot=false hdd-raid6/safe/home/mherold/eos/base - ${zfs}/bin/zfs set com.sun:auto-snapshot=true ssd-raid1/safe - ${zfs}/bin/zfs set com.sun:auto-snapshot=true boot - ''; - }; - }; - in builtins.listToAttrs (map mkSnapService snapshotNames); - - systemd.timers = - let mkSnapTimer = snapName: { - name = "zfs-snapshot-${snapName}"; - value = { - wantedBy = [ "timers.target" ]; - timerConfig = snapshotTimerConfig.${snapName}; - }; - }; - in builtins.listToAttrs (map mkSnapTimer snapshotNames); - + services.zfssnap.enable = true; services.zfs.trim.enable = false; services.zfs.autoScrub = { enable = true; -- cgit v1.2.3