使用kubekey快速搭建k8s集群

项目仓库地址

支持的Kubernetes Versions

安装

选择自己想要下载的版本
复制下载链接并下载

示例:

shell 复制代码
wget https://github.com/kubesphere/kubekey/releases/download/v3.1.5/kubekey-v3.1.5-linux-amd64.tar.gz
解压到需要安装的位置

示例:

shell 复制代码
tar -xf kubekey-v*-linux-amd64.tar.gz -C /usr/local/bin
echo "export PATH=$PATH:/usr/local/bin/kk" >> ~/.bashrc
source ~/.bashrc
命令自动补全

(存疑:执行后没有效果)

shell 复制代码
echo "source <(kk completion -t bash)" >> ~/.bashrc
source ~/.bashrc

搭建k8s集群

示例:

生成一个配置文件
shell 复制代码
kk create config --name config-cluster-example
# 会生成一个config-cluster-example.yaml的配置文件
编辑配置文件
shell 复制代码
vim config-cluster-example.yaml
配置文件概述
yaml 复制代码
apiVersion: kubekey.kubesphere.io/v1alpha2
kind: Cluster
metadata:
  name: config-cluster-example
spec:
  hosts: #配置集群的所有node信息,name是node的主机名,会自动把节点主机名改为name的值,address是节点ip,internalAddress是节点内网ip,user和password是登陆节点的用户名和密码,如果配置了ssh密钥登陆,可以删除user和password字段。
  - {name: node1, address: 172.16.0.2, internalAddress: 172.16.0.2, user: ubuntu, password: "Qcloud@123"}
  - {name: node2, address: 172.16.0.3, internalAddress: 172.16.0.3}
  roleGroups: # 指定节点的身份
    etcd:
    - node1
    control-plane: 
    - node1
    worker:
    - node1
    - node2
  controlPlaneEndpoint:
    ## Internal loadbalancer for apiservers 
    # internalLoadbalancer: haproxy

    domain: lb.kubesphere.local # apiServer监听的域名,默认即可
    address: "172.16.0.2" # apiServer监听的ip,需要自己指定
    port: 6443 # apiServer监听的端口号,默认即可
  kubernetes:
    version: v1.23.15 # 需要安装的集群版本,没有需求默认即可
    clusterName: cluster.local
    autoRenewCerts: true
    containerManager: docker
  etcd:
    type: kubekey
  network:
    plugin: calico
    kubePodsCIDR: 10.233.64.0/18
    kubeServiceCIDR: 10.233.0.0/18
    ## multus support. https://github.com/k8snetworkplumbingwg/multus-cni
    multusCNI:
      enabled: false
  registry:
    privateRegistry: ""
    namespaceOverride: ""
    registryMirrors: []
    insecureRegistries: []
  addons: []
安装必要组件
shell 复制代码
# 所有node都需要执行
apt install -y socat ipset conntrack chrony ipvsadm ebtables
创建集群
shell 复制代码
kk create cluster -yf config-cluster-example.yaml
安装kubectl(已安装则不用再进行安装)
shell 复制代码
# 命令自动补全
echo "source <(kubectl completion bash)" >> ~/.bashrc
source ~/.bashrc

扩展操作

删除集群
shell 复制代码
kk delete cluster <clusterName>
查看kubekey版本
shell 复制代码
kk version
更新集群版本
shell 复制代码
kk upgrade -y --with-kubernetes <version> <clusterName> 或
kk upgrade -y -f <config>.yaml # 推荐
删除node
shell 复制代码
kk delete node <nodeName>
添加node
shell 复制代码
kk add -y nodes <nodeName>或
kk add -y nodes -f <config>.yaml # 推荐
在worker上可以管理集群
shell 复制代码
mkdir -p .kube/config
scp root@<master>:/etc/kubernetes/admin.conf ~/.kube/config # 从master上拷贝 集群管理员的权限
echo "export KUBECONFIG=.kube/config/admin.conf" >> .bashrc
source .bashrc

# KubeKey 默认不会启用 kubectl 自动补全功能。
# 将 completion 脚本添加到你的 ~/.bashrc 文件
echo "source <(kubectl completion bash)" >> ~/.bashrc
source ~/.bashrc
# 将 completion 脚本添加到 /etc/bash_completion.d 目录
kubectl completion bash >/etc/bash_completion.d/kubect
创建一个部署了 KubeSphere 的 Kubernetes 集群 的 配置文件

例如 --with-kubesphere v3.1.0

shell 复制代码
kk create config --with-kubesphere --name <clusterName>
创建一个部署了 KubeSphere 的 Kubernetes 集群

例如 --with-kubesphere v3.1.0

shell 复制代码
kk create cluster --with-kubesphere v3.1.0
从已有的集群创建配置文件
shell 复制代码
kk create config --from-cluster cluster1 -f cluster2.yaml
创建容器是指定 container runtime

可选:docker, crio, containerd and isula

shell 复制代码
kk create cluster --container-manager <container_runtime> -f <config>.yaml
查看kubekey支持的kubernetes的版本
shell 复制代码
kk version --show-supported-k8s
查看kubesphere安装
shell 复制代码
kubectl apply -f https://github.com/kubesphere/ks-installer/releases/download/v3.4.1/kubesphere-installer.yaml

kubectl apply -f https://github.com/kubesphere/ks-installer/releases/download/v3.4.1/cluster-configuration.yaml
查看kubesphere删除
shell 复制代码
kubectl delete --force -f https://github.com/kubesphere/ks-installer/releases/download/v3.4.1/kubesphere-installer.yaml

kubectl delete --force -f https://github.com/kubesphere/ks-installer/releases/download/v3.4.1/cluster-configuration.yaml
相关推荐
熙客2 小时前
阿里云负载均衡SLB的使用
网络·阿里云·云原生·云计算·负载均衡
yannan2019031312 小时前
Docker容器
运维·docker·容器
小宁爱Python13 小时前
Windows Docker Desktop占用C盘空间过大解决办法集合
运维·docker·容器
JAVA学习通13 小时前
发布自己的 jar 包到 Maven 中央仓库 ( mvnrepository.com )
人工智能·docker·自然语言处理·容器·rocketmq
Cloud孙文波14 小时前
探索Apache APISIX:动态高性能API网关
云原生·kubernetes·apisix
木亦汐丫16 小时前
Docker 镜像版本Alpine、Slim、Bookworm、Bullseye、Stretch、Jessie
运维·docker·容器·debian·alpine·slim·bullseye
中草药z19 小时前
【Docker】零基础上手:原理+Ubuntu/Windows GUI 安装 + 镜像源 / 目录优化
运维·ubuntu·docker·容器·gui·安装·cgroups
勇往直前plus19 小时前
如何利用docker部署springboot应用
spring boot·docker·容器
小北爱编程ma20 小时前
【云原生】用Prometheus Operator监听Golang服务指标,并用Granafa可视化展示
云原生
NineData20 小时前
NineData云原生智能数据管理平台新功能发布|2025年9月版
数据库·云原生·devops·ninedata·数据库迁移·数据复制·风险sql管控