nixos-config/config/nas.nix

211 lines
5.1 KiB
Nix
Raw Normal View History

2022-06-12 16:39:15 +01:00
{
config,
modulesPath,
lib,
nixos-hardware,
2023-06-07 05:48:37 +01:00
nixpkgs,
2024-05-23 14:06:26 +01:00
pkgs,
2022-06-12 16:39:15 +01:00
...
} @ args: {
2022-04-24 09:39:44 +01:00
networking.hostName = "nas";
networking.hostId = "70af00ed";
imports = [
(modulesPath + "/installer/scan/not-detected.nix")
./systemd-boot.nix
./services/tpm2.nix
./server.nix
2022-04-24 09:54:25 +01:00
./services/hydra.nix
2022-04-24 09:39:44 +01:00
nixos-hardware.nixosModules.common-cpu-amd
2023-03-18 10:00:15 +01:00
nixos-hardware.nixosModules.common-pc-ssd
2022-05-06 10:54:54 +01:00
./services/syncthing.nix
2022-05-13 08:46:25 +01:00
../modules/tc-cake.nix
2022-05-25 09:36:03 +01:00
./services/cups.nix
2022-06-20 19:15:47 +01:00
./services/iscsi.nix
2022-06-21 13:47:27 +01:00
./services/samba.nix
2022-06-23 09:08:58 +01:00
./services/docker.nix
2023-01-14 14:57:00 +01:00
./users/remote-build.nix
2023-06-14 15:21:08 +01:00
./services/nfs.nix
2023-12-10 11:27:30 +01:00
./services/tempo.nix
2023-12-10 21:08:38 +01:00
./services/loki.nix
2023-12-10 21:27:33 +01:00
./services/prometheus.nix
2024-03-19 10:07:25 +01:00
./services/yiff-stash.nix
2024-03-23 14:01:46 +01:00
./services/reverse-proxy.nix
2024-04-08 21:05:37 +01:00
./services/jellyfin.nix
2024-05-03 05:13:03 +01:00
./services/mautrix-discord.nix
./services/mautrix-telegram.nix
./services/mautrix-whatsapp.nix
2024-05-16 14:42:44 +01:00
./services/mautrix-signal.nix
2024-05-03 05:13:03 +01:00
./services/synapse.nix
./services/heisenbridge.nix
2024-06-01 09:21:59 +01:00
#./services/kubernetes.nix
2022-04-24 09:39:44 +01:00
];
hardware.cpu.amd.updateMicrocode = true;
2023-05-21 18:32:58 +01:00
boot.initrd.availableKernelModules = ["nvme" "xhci_pci" "ahci" "usb_storage" "sd_mod" "bcache"];
2022-06-12 16:39:15 +01:00
boot.initrd.kernelModules = ["igb"];
boot.kernelModules = ["kvm-amd"];
2022-04-24 09:39:44 +01:00
boot.extraModulePackages = [
config.boot.kernelPackages.zenpower
];
fileSystems."/" = {
2024-07-20 14:57:26 +02:00
device = "/dev/bcache0";
fsType = "btrfs";
options = ["subvol=root" "compress=zstd"];
2024-04-25 06:39:15 +01:00
};
2024-07-20 14:57:26 +02:00
fileSystems."/home" = {
device = "/dev/bcache0";
fsType = "btrfs";
options = ["subvol=home" "compress=zstd"];
2024-04-25 06:39:15 +01:00
};
fileSystems."/nix" = {
2024-07-20 14:57:26 +02:00
device = "/dev/bcache0";
fsType = "btrfs";
options = ["subvol=nix" "compress=zstd" "noatime"];
2024-04-25 06:39:15 +01:00
};
2024-07-20 14:57:26 +02:00
services.snapper.configs.main = {
SUBVOLUME = "/";
TIMELINE_LIMIT_HOURLY = 5;
TIMELINE_LIMIT_DAILY = 7;
TIMELINE_LIMIT_WEEKLY = 4;
TIMELINE_LIMIT_MONTHLY = 12;
TIMELINE_LIMIT_YEARLY = 0;
};
services.beesd.filesystems.root = {
spec = "/";
hashTableSizeMB = 2048;
verbosity = "crit";
extraOptions = ["--loadavg-target" "5.0"];
2022-04-24 09:39:44 +01:00
};
fileSystems."/boot" = {
2023-03-18 10:00:15 +01:00
device = "/dev/nvme0n1p1";
fsType = "vfat";
2024-04-25 06:39:15 +01:00
};
2022-04-24 09:39:44 +01:00
environment.etc."sysconfig/lm_sensors".text = ''
# Generated by sensors-detect on Sun Apr 24 08:31:51 2022
# This file is sourced by /etc/init.d/lm_sensors and defines the modules to
# be loaded/unloaded.
#
# The format of this file is a shell script that simply defines variables:
# HWMON_MODULES for hardware monitoring driver modules, and optionally
# BUS_MODULES for any required bus driver module (for example for I2C or SPI).
HWMON_MODULES="it87"
'';
nix.settings.cores = 12;
2023-06-03 15:38:27 +01:00
nix.settings.system-features = [
"kvm"
"nixos-test"
"big-parallel"
"benchmark"
"gccarch-znver1"
"gccarch-skylake"
"ca-derivations"
];
2022-04-24 09:39:44 +01:00
boot.binfmt.emulatedSystems = [
"armv7l-linux"
"powerpc-linux"
"powerpc64-linux"
"powerpc64le-linux"
"wasm32-wasi"
2023-10-19 09:02:43 +01:00
"riscv32-linux"
"riscv64-linux"
2022-04-24 09:39:44 +01:00
];
hardware.enableRedistributableFirmware = true;
nix.settings.substituters = lib.mkForce [
"https://attic.chir.rs/chir-rs/"
"https://cache.nixos.org/"
2022-04-24 09:39:44 +01:00
];
nix.daemonCPUSchedPolicy = "idle";
nix.daemonIOSchedClass = "idle";
2022-05-28 20:53:40 +01:00
system.stateVersion = "22.05";
2022-06-12 16:39:15 +01:00
home-manager.users.darkkirb = import ./home-manager/darkkirb.nix {
desktop = false;
inherit args;
};
2022-05-11 12:01:42 +01:00
networking.tc_cake = {
2023-03-18 10:02:19 +01:00
enp2s0f0u4 = {
2022-05-13 10:27:06 +01:00
disableOffload = true;
2022-05-11 12:01:42 +01:00
shapeEgress = {
bandwidth = "4mbit";
extraArgs = "docsis nat ack-filter";
};
shapeIngress = {
bandwidth = "33mbit";
2023-03-18 10:02:19 +01:00
ifb = "ifb4enp2s0f0u4";
2022-05-11 12:01:42 +01:00
};
};
};
2022-11-06 10:51:36 +01:00
services.postgresql.settings = {
max_connections = 200;
shared_buffers = "4GB";
effective_cache_size = "12GB";
maintenance_work_mem = "1GB";
checkpoint_completion_target = 0.9;
wal_buffers = "16MB";
default_statistics_target = 100;
2023-03-18 10:21:03 +01:00
random_page_cost = 1.1;
effective_io_concurrency = 200;
2022-11-06 10:51:36 +01:00
work_mem = "5242kB";
min_wal_size = "1GB";
max_wal_size = "4GB";
max_worker_processes = 12;
max_parallel_workers_per_gather = 4;
max_parallel_workers = 12;
max_parallel_maintenance_workers = 4;
};
2023-02-01 21:01:01 +01:00
services.tailscale.useRoutingFeatures = "both";
2023-03-27 19:53:52 +01:00
hardware.sane.brscan4.enable = true;
2023-10-11 19:10:17 +01:00
swapDevices = [
{
device = "/dev/sda2";
}
{
device = "/dev/sdb2";
}
{
device = "/dev/sdc2";
}
];
2024-04-08 21:05:37 +01:00
hardware.opengl = {
enable = true;
driSupport32Bit = true;
};
services.xserver.videoDrivers = ["nvidia"];
hardware.nvidia = {
modesetting.enable = true;
powerManagement.enable = false;
powerManagement.finegrained = false;
open = false;
nvidiaSettings = true;
package = config.boot.kernelPackages.nvidiaPackages.stable;
};
2024-05-06 09:58:52 +01:00
services.restic.backups.sysbackup = {
paths = ["/persist"];
pruneOpts = [
"--keep-daily 7"
"--keep-weekly 4"
"--keep-monthly 12"
"--keep-yearly 10"
];
};
system.autoUpgrade.allowReboot = true;
2024-05-23 14:06:26 +01:00
virtualisation.docker = {
enable = true;
2024-06-11 11:07:47 +02:00
#enableNvidia = true;
2024-05-23 14:06:26 +01:00
};
environment.systemPackages = with pkgs; [docker runc];
2022-04-24 09:39:44 +01:00
}