SkillAgentSearch skills...

Kubefire

KubeFire 🔥, creates and manages Kubernetes Clusters using Firecracker microVMs

Install / Use

/learn @innobead/Kubefire
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

What is KubeFire? 🔥

KubeFire is a tool to create and manage Kubernetes clusters running on Firecracker microVMs via weaveworks/ignite.

  • Uses independent root filesystem (rootfs) and kernel from OCI images instead of traditional VM images like qcow2, vhd, etc.
  • Uses containerd to manage Firecracker processes.
  • Supports different cluster bootstrappers to provision Kubernetes clusters like Kubeadm, K3s, RKE2, and K0s.
  • Supports deploying clusters on different architectures like x86_64/AMD64 and ARM64/AARCH64 (e.g., K3s, RKE2, K0s).

kubefire in action

Getting Started

Installing KubeFire

For official releases, please install the latest version via the command below or use huber:

curl -sfSL https://raw.githubusercontent.com/innobead/kubefire/master/hack/install-release-kubefire.sh | bash

or

huber install kubefire

For development purpose, please make sure go 1.14 installed, then build and install kubefire in the GOBIN path.

make install

Quickstart

Running below commands is to quickly have a cluster deployed by kubeadm running in minutes.

kubefire install
kubefire cluster create demo

Installing or Updating Prerequisites

To be able to run kubefire commands w/o issues like node/cluster management, there are some prerequisites to have. Please run kubefire install command with root permission (or sudo without password) to install or update these prerequisites via the below steps.

  • Check virtualization supported
  • Install necessary components including runc, containerd, CNI plugins, and Ignite. See below minimum required versions of components
    • RuncVersion >= v1.1.3
    • ContainerdVersion >= v1.6.6
    • CniVersion >= v1.1.1
    • IgniteVersion >= v0.10.0

Notes:

  • To uninstall the prerequisites, run kubefire uninstall.
  • To check the installation status, run kubefire info.

asciicast

Bootstrapping Cluster

Bootstrapping with command options, or a declarative config file

cluster create provides detailed options to configure the cluster, but it also provides --config to accept a cluster configuration file to bootstrap the cluster as below commands.

With command options

$ kubefire cluster create -h
Creates cluster

Usage:
  kubefire cluster create [name] [flags]

Flags:
  -b, --bootstrapper string    Bootstrapper type, options: [kubeadm, k3s, rke2, k0s] (default "kubeadm")
  -c, --config string          Cluster configuration file (ex: use 'config-template' command to generate the default cluster config)
  -o, --extra-options string   Extra options (ex: key=value,...) for bootstrapper
  -f, --force                  Force to recreate if the cluster exists
  -h, --help                   help for create
  -i, --image string           Rootfs container image (default "ghcr.io/innobead/kubefire-opensuse-leap:15.2")
      --kernel-args string     Kernel arguments (default "console=ttyS0 reboot=k panic=1 pci=off ip=dhcp security=apparmor apparmor=1")
      --kernel-image string    Kernel container image (default "ghcr.io/innobead/kubefire-ignite-kernel:4.19.125-amd64")
      --master-count int       Count of master node (default 1)
      --master-cpu int         CPUs of master node (default 2)
      --master-memory string   Memory of master node (default "2GB")
      --master-size string     Disk size of master node (default "10GB")
      --no-cache               Forget caches
      --no-start               Don't start nodes
  -k, --pubkey string          Public key
  -v, --version string         Version of Kubernetes supported by bootstrapper (ex: v1.18, v1.18.8, empty)
      --worker-count int       Count of worker node
      --worker-cpu int         CPUs of worker node (default 2)
      --worker-memory string   Memory of worker node (default "2GB")
      --worker-size string     Disk size of worker node (default "10GB")

Global Flags:
  -l, --log-level string   log level, options: [panic, fatal, error, warning, info, debug, trace] (default "info")

With declarative config file

# Geneate a cluster template configuration, then update the config as per your needs
$ kubefire cluster config-template > cluster.yaml
$ cat cluster.yaml
name: ""
bootstrapper: kubeadm
pubkey: ""
prikey: ""
version: ""
image: ghcr.io/innobead/kubefire-opensuse-leap:15.2
kernel_image: ghcr.io/innobead/kubefire-ignite-kernel:4.19.125-amd64
kernel_args: console=ttyS0 reboot=k panic=1 pci=off ip=dhcp security=apparmor apparmor=1
extra_options: {}
deployed: false
master:
  count: 1
  memory: 2GB
  cpus: 2
  disk_size: 10GB
worker:
  count: 0
  memory: 2GB
  cpus: 2
  disk_size: 10GB

Create a cluster with the config file

kubefire cluster create demo --config=cluster.yaml

Bootstrapping with selectable Kubernetes versions

# Create a cluster with the latest versions w/o any specified version
$ kubefire cluster create demo

# Create a cluster with the latest patch version of v1.18
$ kubefire cluster create demo --version=v1.18

# Create a cluster with a valid specific version v1.18.8
$ kubefire cluster create demo --version=v1.18.8

# Create a cluster with the latest patch version of supported minor releases
$ kubefire cluster create demo --version=v1.17
$ kubefire cluster create demo --version=v1.16

# If the version is outside the supported versions (last 3 minor versions given the latest is v1.18), the cluster creation will be not supported
$ kubefire cluster create demo --version=v1.15

Bootstrapping with Kubeadm

Supports the latest supported version and last 3 minor versions.

kubefire cluster create demo --bootstrapper=kubeadm

Add extra Kubeadm deployment options

To add extra deployment options of the control plane components, use --extra-options of cluster create command to provide init_options, api_server_options, controller_manager_options or scheduler_options key-value pairs as the below example.

Note: the key-value pairs in --extra-options are separated by comma.

  • Add extra options of kubeadm init into init_options='<option>,...'.
  • Add extra options of API Server into api_server_options='<option>,...'.
  • Add extra options of Controller Manager into controller_manager_options='<option>,...'.
  • Add extra options of Scheduler into scheduler_options='<option>,...'.
kubefire cluster create demo --bootstrapper=kubeadm --extra-options="init_options='--service-dns-domain=yourcluster.local' api_server_options='--audit-log-maxage=10'"

asciicast

Bootstrapping with K3s

Supports the latest supported version and last 3 minor versions.

Please note that K3s only officially supports Ubuntu 16.04 and 18.04, the kernel versions of which are 4.4 and 4.15. Therefore, if using the prebuilt kernels, please use 4.19 (which is the default kernel used) instead of 5.4, otherwise there will be some unexpected errors happening. For rootfs, it's no problem to use other non-Ubuntu images.

kubefire cluster create demo --bootstrapper=k3s

Bootstrapping with K3s on ARM64

From 0.3.0, it's able to deploy K3s cluster on ARM64 architecture.

Notes: K3s supported only, and Kubeadm will be planned to support in the future.

asciicast

Add extra K3s deployment options

To add extra deployment options of the server or agent nodes, use --extra-options of cluster create command to provide server_install_options or agent_install_options key-value pairs as the below example.

Note: the key-value pairs in --extra-options are separated by a comma.

  • Add extra options of k3s server into server_install_options='<k3s server option>,...'.
  • Add extra options of k3s agent into agent_install_options='<k3s agent option>,...'.
kubefire cluster create demo --bootstrapper=k3s --extra-options="server_install_options='--disable=traefik,--disable=metrics-server'"

asciicast

Bootstrapping with RKE2

kubefire cluster create demo --bootstrapper=rke2

Add extra RKE2 deployment options

To add extra deployment options of the RKE2 cluster, use --extra-options of cluster create command to provide the below options as key-value pairs.

Note: the key-value pairs in --extra-options are separated by a comma.

  • Add extra options of rke2 server into server_install_options='<rke2 server option>,...'.
  • Add extra options of rke2 agent into agent_install_options='<rke2 agent option>,...'.
kubefire cluster create demo --bootstrapper=rke2 --extra-options="server_install_options='--node-label=label1,--node-taint=key=value:NoSchedule'"

Bootstrapping with K0s

kubefire cluster create demo --bootstrapper=k0s

Add extra K0s deployment options

To add extra deployment options of the K0s cluster, use --extra-options of cluster create command to provide the below options as key-value pairs.

Note: the key-value pairs in --extra-options are separated by a comma.

  • Add extra options of k0s server into server_install_options='<k0s server option>,...'
  • Add extra options of k0s worker into worker_install_options='<k0s worker option>,...'
  • Add cluster_config_file into cluster_config_file='<k0s customized cluster.yaml>,...'
kubefire cluster create demo --bootstrapper=k0s --extra-options="server_install_options='--debug' clu

Related Skills

View on GitHub
GitHub Stars612
CategoryDevelopment
Updated11d ago
Forks39

Languages

Go

Security Score

100/100

Audited on Mar 20, 2026

No findings