79 lines
2.1 KiB
Nix
79 lines
2.1 KiB
Nix
{ config, pkgs, ... }:
|
||
|
||
{
|
||
imports =
|
||
[
|
||
./hardware-configuration.nix
|
||
./network.nix
|
||
];
|
||
|
||
boot.loader.systemd-boot = {
|
||
enable = true;
|
||
extraInstallCommands = ''
|
||
${pkgs.coreutils}/bin/cp -r /boot/* /boot2
|
||
'';
|
||
};
|
||
# boot.kernelParams = [ "video=VGA-1:1024x768@30" ];
|
||
boot.loader.efi.canTouchEfiVariables = true;
|
||
boot.supportedFilesystems = [ "zfs" ];
|
||
# boot.kernelPackages = config.boot.zfs.package.latestCompatibleLinuxPackages;
|
||
# Pin Kernel Version as 6.6.28 has a broken networking driver
|
||
boot.kernelPackages = pkgs.linuxPackagesFor (pkgs.linux_6_6.override {
|
||
argsOverride = rec {
|
||
src = pkgs.fetchurl {
|
||
url = "mirror://kernel/linux/kernel/v6.x/linux-${version}.tar.xz";
|
||
sha256 = "sha256-Y55QBg48jyPtAXyxDP6sxrqI/1WDgSu3aFm0zGoSgpE=";
|
||
};
|
||
version = "6.6.27";
|
||
modDirVersion = "6.6.27";
|
||
};
|
||
});
|
||
|
||
services.zfs = {
|
||
trim.enable = true;
|
||
autoScrub.enable = true;
|
||
};
|
||
|
||
# Set your time zone.
|
||
time.timeZone = "Europe/Berlin";
|
||
i18n.defaultLocale = "en_US.UTF-8";
|
||
|
||
# prevent fork bombs
|
||
security.pam.loginLimits = [
|
||
{
|
||
domain = "@users";
|
||
item = "nproc";
|
||
type = "hard";
|
||
value = "2000";
|
||
}
|
||
{
|
||
domain = "@nixbld";
|
||
item = "nproc";
|
||
type = "hard";
|
||
value = "10000";
|
||
}
|
||
];
|
||
# Enable the OpenSSH daemon.
|
||
services.openssh.enable = true;
|
||
services.openssh.settings.PermitRootLogin = "yes";
|
||
|
||
systemd = {
|
||
services.nix-daemon.serviceConfig = {
|
||
MemoryMax = "32G";
|
||
};
|
||
# all users together may not use more than $MemoryMax of RAM
|
||
slices."user".sliceConfig = {
|
||
MemoryMax = "32G";
|
||
};
|
||
};
|
||
|
||
# This value determines the NixOS release from which the default
|
||
# settings for stateful data, like file locations and database versions
|
||
# on your system were taken. It‘s perfectly fine and recommended to leave
|
||
# this value at the release version of the first install of this system.
|
||
# Before changing this value read the documentation for this option
|
||
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
|
||
system.stateVersion = "23.05"; # Did you read the comment?
|
||
}
|
||
|