{ config, pkgs, lib, ... }: { imports = [ ../common/main.nix ../common/monitoring.nix ]; # Select the this using the ID to avoid mismatches boot.loader.grub.device = "/dev/disk/by-id/wwn-0x55cd2e414d53562d"; environment.systemPackages = with pkgs; [ ceph ]; services.slurm = { client.enable = lib.mkForce false; }; networking = { hostName = "bay"; interfaces.eno1.ipv4.addresses = [ { address = "10.0.40.40"; prefixLength = 24; } ]; interfaces.ibp5s0.ipv4.addresses = [ { address = "10.0.42.40"; prefixLength = 24; } ]; }; services.ceph = { enable = true; global = { fsid = "9c8d06e0-485f-4aaf-b16b-06d6daf1232b"; monHost = "10.0.42.40"; monInitialMembers = "10.0.42.40"; publicNetwork = "10.0.42.40/24"; clusterNetwork = "10.0.42.40/24"; }; extraConfig = { # Only log to stderr so it appears in the journal "log_file" = "/dev/null"; "mon_cluster_log_file" = "/dev/null"; "log_to_stderr" = "true"; "err_to_stderr" = "true"; "log_to_file" = "false"; }; mds = { enable = true; daemons = [ "mds0" "mds1" ]; extraConfig = { "host" = "10.0.42.40"; }; }; mgr = { enable = true; daemons = [ "bay" ]; }; mon = { enable = true; daemons = [ "bay" ]; }; osd = { enable = true; # One daemon per NVME disk daemons = [ "0" "1" "2" "3" ]; extraConfig = { "osd crush chooseleaf type" = "0"; "osd journal size" = "10000"; "osd pool default min size" = "2"; "osd pool default pg num" = "200"; "osd pool default pgp num" = "200"; "osd pool default size" = "3"; }; }; }; # Missing service for volumes, see: # https://www.reddit.com/r/ceph/comments/14otjyo/comment/jrd69vt/ systemd.services.ceph-volume = { enable = true; description = "Ceph Volume activation"; unitConfig = { Type = "oneshot"; After = "local-fs.target"; Wants = "local-fs.target"; }; path = [ pkgs.ceph pkgs.util-linux pkgs.lvm2 pkgs.cryptsetup ]; serviceConfig = { KillMode = "none"; Environment = "CEPH_VOLUME_TIMEOUT=10000"; ExecStart = "/bin/sh -c 'timeout $CEPH_VOLUME_TIMEOUT ${pkgs.ceph}/bin/ceph-volume lvm activate --all --no-systemd'"; TimeoutSec = "0"; }; wantedBy = [ "multi-user.target" ]; }; }