k0smotron 一键创建 K8s Control Plane(K8s in K8s 模式)

想要在本地快速创建和管理多个 Kubernetes 集群吗?k0smotron 让这一切变得简单高效!

什么是 k0smotron?

k0smotron 是一个开源工具,它允许你在现有的 Kubernetes 集群(meta 管理集群)中创建和管理多个集群的控制平面。这意味着你可以在一个主集群中运行多个独立的 Kubernetes 集群控制面,完美适合多租户环境、测试场景和开发环境。

实战:使用 Kind 集群一键创建 k0smotron 控制面

步骤 1:创建 Kind 集群
bash 复制代码
cat > kind-cluster.yaml << EOF
kind: Cluster
apiVersion: kind.x-k8s.io/v1alpha4
nodes:
- role: control-plane
  image: kindest/node:v1.34.0@sha256:7416a61b42b1662ca6ca89f02028ac133a309a2a30ba309614e8ec94d976dc5a
- role: worker
  image: kindest/node:v1.34.0@sha256:7416a61b42b1662ca6ca89f02028ac133a309a2a30ba309614e8ec94d976dc5a
- role: worker
  image: kindest/node:v1.34.0@sha256:7416a61b42b1662ca6ca89f02028ac133a309a2a30ba309614e8ec94d976dc5a
- role: worker
  image: kindest/node:v1.34.0@sha256:7416a61b42b1662ca6ca89f02028ac133a309a2a30ba309614e8ec94d976dc5a
EOF

kind create cluster --config kind-cluster.yaml
步骤 2:安装 k0smotron

k0smotron 依赖 cert-manager 组件,需预先在集群中安装:

bash 复制代码
kubectl apply -f https://github.com/cert-manager/cert-manager/releases/download/v1.19.1/cert-manager.yaml

然后,安装 k0smotron:

bash 复制代码
kubectl apply --server-side=true -f https://docs.k0smotron.io/stable/install.yaml
步骤 3:验证安装
bash 复制代码
kubectl get pods -n k0smotron
步骤 4:创建第一个集群控制面
bash 复制代码
kubectl apply -f - <<EOF
apiVersion: k0smotron.io/v1beta1
kind: Cluster
metadata:
  name: my-k0smotron
spec: {}
EOF
步骤 5:获取集群连接信息
bash 复制代码
kubectl get secret my-k0smotron-kubeconfig -o jsonpath='{.data.value}' | base64 -d > ~/.kube/child.conf
yaml 复制代码
apiVersion: v1
clusters:
- cluster:
    certificate-authority-data: xxx
    server: https://10.244.2.3:30443
  name: my-k0smotron-k0s
contexts:
- context:
    cluster: my-k0smotron-k0s
    user: my-k0smotron-admin
  name: my-k0smotron-admin@my-k0smotron-k0s
current-context: my-k0smotron-admin@my-k0smotron-k0s
kind: Config
preferences: {}
users:
- name: my-k0smotron-admin
  user:
    client-certificate-data: xxx
    client-key-data: xxx

默认使用 NodePort 连接新建的控制面:

bash 复制代码
kubectl get svc kmc-my-k0smotron

使用创建出的控制面集群

bash 复制代码
kubectl version --kubeconfig ~/.kube/child.conf
相关推荐
江畔何人初3 小时前
pod的定义以及创建过程
linux·运维·云原生
等什么君!4 小时前
docker -数据卷技术
运维·docker·容器
上天_去_做颗惺星 EVE_BLUE5 小时前
Docker高效使用指南:从基础到实战模板
开发语言·ubuntu·docker·容器·mac·虚拟环境
Gary董6 小时前
高并发的微服务架构如何设计
微服务·云原生·架构
东哥爱编程6 小时前
使用Runpod进行gpu serverless推理
云原生·serverless
好好沉淀7 小时前
Docker开发笔记(详解)
运维·docker·容器
Ankie Wan8 小时前
cgroup(Control Group)是 Linux 内核提供的一种机制,用来“控制、限制、隔离、统计”进程对系统资源的使用。
linux·容器·cgroup·lxc
lcx_defender9 小时前
【Docker】Docker部署运行nacos
运维·docker·容器
啦啦啦小石头10 小时前
docker添加用户权限不使用sudo
运维·docker·容器
天才奇男子11 小时前
《深度解析HAProxy七层代理:原理、配置与最佳实践》
linux·运维·微服务·云原生