104 lines
2.6 KiB
Nix
Raw Normal View History

2025-12-16 19:31:33 -05:00
{
config,
lib,
pkgs,
...
}:
let
# shellCommand = cmd: (lib.concatMapStringsSep " " lib.strings.escapeShellArg cmd);
shellCommand = cmd: (builtins.concatStringsSep " " cmd);
2025-12-29 22:44:04 -05:00
to_yaml_file = ((import ../../functions/to_yaml.nix) { inherit pkgs; }).to_yaml_file;
2025-12-29 21:54:27 -05:00
kubelet_config = {
kind = "KubeletConfiguration";
apiVersion = "kubelet.config.k8s.io/v1beta1";
address = "0.0.0.0";
authentication = {
anonymous = {
enabled = false;
};
webhook = {
enabled = true;
};
x509 = {
clientCAFile = "/.persist/keys/kube/ca.crt";
};
};
authorization = {
mode = "Webhook";
};
cgroupDriver = "systemd";
containerRuntimeEndpoint = "unix:///var/run/containerd/containerd.sock";
enableServer = true;
failSwapOn = false;
maxPods = 16;
memorySwap = {
swapBehavior = "NoSwap";
};
port = 10250;
2025-12-29 22:44:04 -05:00
resolvConf = "/run/systemd/resolve/resolv.conf";
2025-12-29 21:54:27 -05:00
registerNode = true;
runtimeRequestTimeout = "15m";
tlsCertFile = "/.persist/keys/kube/kubelet.crt";
tlsPrivateKeyFile = "/.persist/keys/kube/kubelet.key";
2025-12-29 22:44:04 -05:00
clusterDomain = "cluster.local";
clusterDNS = [
"10.197.0.10"
"fd00:3e42:e349::10"
];
2025-12-29 21:54:27 -05:00
};
kubelet_config_file = (to_yaml_file "kubelet-config.yaml" kubelet_config);
2025-12-16 19:31:33 -05:00
in
{
imports = [ ];
options.me = {
kubelet.enable = lib.mkOption {
type = lib.types.bool;
default = false;
example = true;
description = "Whether we want to install kubelet.";
};
};
config = lib.mkIf config.me.kubelet.enable {
systemd.services.kubelet = {
enable = true;
description = "Kubernetes Kubelet";
documentation = [ "https://github.com/kubernetes/kubernetes" ];
wantedBy = [ "kubernetes.target" ];
after = [ "containerd.service" ];
requires = [ "containerd.service" ];
2025-12-16 21:48:44 -05:00
path = with pkgs; [
util-linux
];
2025-12-16 19:31:33 -05:00
unitConfig.DefaultDependencies = "no";
serviceConfig = {
ExecStart = (
shellCommand [
"${pkgs.kubernetes}/bin/kubelet"
2025-12-29 21:54:27 -05:00
"--config=${kubelet_config_file}"
2025-12-16 21:07:39 -05:00
"--kubeconfig=/.persist/keys/kube/kubelet.kubeconfig"
2025-12-16 19:31:33 -05:00
"--v=2"
]
);
Restart = "on-failure";
RestartSec = 5;
# ConfigurationDirectory = "kubernetes";
# CPUAccounting = "true";
# IPAccounting = "true";
# KillMode = "process";
# MemoryAccounting = "true";
# StartLimitInterval = 0;
# RuntimeDirectory = "kubelet";
# StateDirectory = "kubelet";
};
};
2025-12-18 22:28:03 -05:00
networking.firewall.allowedTCPPorts = [
10250
];
2025-12-16 19:31:33 -05:00
};
}