-
检查虚拟机默认网卡配置
a. 默认网卡为
eth0
, 如果环境实际网卡不是eth0
,则需要手动指定网卡名称:编辑 /etc/kubez/globals.yml 文件,取消 network_interface: "eth0" 的注解,并修改为实际网卡名称
-
确认集群环境连接地址
a. 内网连接:
编辑 /etc/kubez/globals.yml 文件,取消 #kube_vip_address: "172.16.50.250" 的注解,并修改为 vip 地址
b. 公网地址:
编辑 /etc/kubez/globals.yml 文件,取消 #kube_vip_address: "172.16.50.250" 的注解,并修改为实际公网地址( LB 地址), 云平台环境需要放通公网ip到后端 master 节点的6443端口
-
配置工作目录下的
multinode
配置文件, 根据实际情况添加主机信息, 并完成如下配置- 配置部署节点的
/etc/hosts
, 添加 kubernetes 节点的ip和主机名解析 - multinode 配置格式,推荐:
- 如果 cri 选择 docker,则仅需配置 [docker-master] 和 [docker-node]
# 如果是高可用集群,则需要在 [docker-master] 添加奇数个主机名 [docker-master] kube01 kube02 kube03 [docker-node] kube0x kube0x kube0x [storage] kube01
- 如果 cri 选择 containerd,则仅需配置 [containerd-master] 和 [containerd-node]
# 如果是高可用集群,则需要在 [containerd-master] 添加奇数个主机名 [containerd-master] kube01 kube02 kube03 [containerd-node] kube0x kube0x kube0x [storage] kube01
- 配置部署节点的
-
打通
部署节点
(运行kubez-ansible
的节点) 到其他node
节点的免密登陆 批量开启免密登陆 或者 配置密码/密钥 -
(可选)修改 kubernetes 镜像仓库
编辑 /etc/kubez/globals.yml 文件,修改 image_repository: "" 为期望镜像仓库,默认是阿里云 registry.cn-hangzhou.aliyuncs.com/google_containers
-
(可选)修改基础应用镜像仓库
编辑 /etc/kubez/globals.yml 文件,修改 app_image_repository: "" 为期望镜像仓库,默认是 pixiu镜像仓库 ccr.ccs.tencentyun.com/pixiucloud
-
执行如下命令,进行
kubernetes
的依赖安装kubez-ansible -i multinode bootstrap-servers
-
根据实际需要,调整配置文件
/etc/kubez/globals.yml
enable_kubernetes_ha: "yes" # 启用多控高可用, 需保证 multinode 的 control 组为奇数 kube_vip_address: "x.x.x.x" # 如果是公网 LB,则填写公网 LB 地址,如果是自建高可用则填写 vip enable_haproxy: "yes" # 部署 haproxy and keepalived,如果是使用公网 LB 则不需要开启 # 启用 haproxy + keepalived 时, 监听端口推荐使用 8443 kube_vip_port: 6443 cluster_cidr: "172.30.0.0/16" # pod network service_cidr: "10.254.0.0/16" # service network # network cni, 现支持flannel 和 calico, 默认是 flannel enable_calico: "no"
-
执行如下命令,进行
kubernetes
的集群安装kubez-ansible -i multinode deploy
-
验证环境
[root@kube01 ~]# kubectl get node
NAME STATUS ROLES AGE VERSION
kube01 Ready control-plane,master 21h v1.23.6
kube02 Ready <none> 21h v1.23.6
kube03 Ready <none> 3h48m v1.23.6
- (可选)启用 kubectl 命令行补全
kubez-ansible -i multinode post-deploy