Difference between revisions of "K3s"

From NixOS Wiki
Jump to: navigation, search
(add flannel config)
(Raspberry Pi not working due to memory cgroup fixed)
Line 52: Line 52:
 
   ];
 
   ];
 
</syntaxHighlight>
 
</syntaxHighlight>
 +
 +
== Troubleshooting ==
 +
 +
=== Raspbbery Pi not working ===
 +
 +
If the k3s.service/k3s server does not start and gives you th error <code>FATA[0000] failed to find memory cgroup (v2)</code> Here's the github issue: https://github.com/k3s-io/k3s/issues/2067 .
 +
 +
To fix the problem you can add these things to your configuration.nix.
 +
 +
<source lang="nix">  boot.kernelParams = [
 +
    "cgroup_enable=cpuset" "cgroup_memory=1" "cgroup_enable=memory"
 +
  ];
 +
</source>
 +
  
 
[[Category:Applications]]
 
[[Category:Applications]]
 
[[Category:Server]]
 
[[Category:Server]]
 
[[Category:orchestration]]
 
[[Category:orchestration]]

Revision as of 20:07, 21 January 2023

K3s is a simplified version of Kubernetes. It bundles all components for a kubernetes cluster into a few of small binaries.

Single node setup

{
  # This is required so that pod can reach the API server (running on port 6443 by default)
  networking.firewall.allowedTCPPorts = [ 6443 ];
  services.k3s.enable = true;
  services.k3s.role = "server";
  services.k3s.extraFlags = toString [
    # "--kubelet-arg=v=4" # Optionally add additional args to k3s
  ];
  environment.systemPackages = [ pkgs.k3s ];
}

After enabling, you can access your cluster through sudo k3s kubectl i.e. sudo k3s kubectl cluster-info, or by using the generated kubeconfig file in /etc/rancher/k3s/k3s.yaml

Multi-node setup

See this real world example. You might want to ignore some parts of it i.e. the monitoring as this is specific to our setup. The K3s server needs to import modules/k3s/server.nix and an agent modules/k3s/agent.nix. Tipp: You might run into issues with coredns not being reachable from agent nodes. Right now we disable the NixOS firewall all together until we find a better solution.

ZFS support

K3s's builtin containerd does not support the zfs snapshotter. However it is possible to configure it to use an external containerd:

  virtualisation.containerd = {
    enable = true;
    settings =
      let
        fullCNIPlugins = pkgs.buildEnv {
          name = "full-cni";
          paths = with pkgs;[
            cni-plugins
            cni-plugin-flannel
          ];
        };
      in {
        plugins."io.containerd.grpc.v1.cri".cni = {
          bin_dir = "${fullCNIPlugins}/bin";
          conf_dir = "/var/lib/rancher/k3s/agent/etc/cni/net.d/";
        };
      };
  };
  # TODO describe how to enable zfs snapshotter in containerd
  services.k3s.extraFlags = toString [
    "--container-runtime-endpoint unix:///run/containerd/containerd.sock"
  ];

Troubleshooting

Raspbbery Pi not working

If the k3s.service/k3s server does not start and gives you th error FATA[0000] failed to find memory cgroup (v2) Here's the github issue: https://github.com/k3s-io/k3s/issues/2067 .

To fix the problem you can add these things to your configuration.nix.

  boot.kernelParams = [
    "cgroup_enable=cpuset" "cgroup_memory=1" "cgroup_enable=memory"
  ];