105 lines
2.7 KiB
Nix
105 lines
2.7 KiB
Nix
{
|
|
config,
|
|
lib,
|
|
pkgs,
|
|
...
|
|
}:
|
|
|
|
let
|
|
# shellCommand = cmd: (lib.concatMapStringsSep " " lib.strings.escapeShellArg cmd);
|
|
shellCommand = cmd: (builtins.concatStringsSep " " cmd);
|
|
to_yaml_file = ((import ../../../functions/to_yaml.nix) { inherit pkgs; }).to_yaml_file;
|
|
|
|
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;
|
|
# resolvConf = "/run/systemd/resolve/resolv.conf";
|
|
resolvConf = "${./files/resolv.conf}";
|
|
registerNode = true;
|
|
runtimeRequestTimeout = "15m";
|
|
tlsCertFile = "/.persist/keys/kube/kubelet.crt";
|
|
tlsPrivateKeyFile = "/.persist/keys/kube/kubelet.key";
|
|
# clusterDomain = "cluster.local";
|
|
# clusterDNS = [
|
|
# "10.197.0.10"
|
|
# "fd00:3e42:e349::10"
|
|
# ];
|
|
};
|
|
kubelet_config_file = (to_yaml_file "kubelet-config.yaml" kubelet_config);
|
|
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" ];
|
|
path = with pkgs; [
|
|
util-linux
|
|
];
|
|
unitConfig.DefaultDependencies = "no";
|
|
serviceConfig = {
|
|
ExecStart = (
|
|
shellCommand [
|
|
"${pkgs.kubernetes}/bin/kubelet"
|
|
"--config=${kubelet_config_file}"
|
|
"--kubeconfig=/.persist/keys/kube/kubelet.kubeconfig"
|
|
"--v=2"
|
|
]
|
|
);
|
|
Restart = "on-failure";
|
|
RestartSec = 5;
|
|
# ConfigurationDirectory = "kubernetes";
|
|
# CPUAccounting = "true";
|
|
# IPAccounting = "true";
|
|
# KillMode = "process";
|
|
# MemoryAccounting = "true";
|
|
# StartLimitInterval = 0;
|
|
# RuntimeDirectory = "kubelet";
|
|
# StateDirectory = "kubelet";
|
|
};
|
|
};
|
|
|
|
networking.firewall.allowedTCPPorts = [
|
|
10250
|
|
];
|
|
};
|
|
}
|