Skip to content

Latest commit

 

History

History
103 lines (78 loc) · 3.24 KB

multinode.md

File metadata and controls

103 lines (78 loc) · 3.24 KB

多节点&高可用集群

依赖条件

部署步骤

  1. 检查虚拟机默认网卡配置:

    a. 默认网卡为 eth0, 如果环境实际网卡不是 eth0,则需要手动指定网卡名称:

     编辑 /etc/kubez/globals.yml 文件,取消 network_interface: "eth0" 的注解,并修改为实际网卡名称
  2. 确认集群环境连接地址:

    a. 内网连接: 无需更改

    b. 公网地址:

    编辑 /etc/kubez/globals.yml 文件,取消 #kube_vip_address: "172.16.50.250" 的注解,并修改为实际公网地址(高可用场景时为 LB 地址), 云平台环境需要放通公网ip到后端 master 节点的6443端口
  3. 配置工作目录下的 multinode 配置文件, 根据实际情况添加主机信息, 并完成如下配置

    • 配置部署节点的 /etc/hosts, 添加 kubernetes 节点的ip和主机名解析
    • multinode 配置格式,推荐:
      • 如果 cri 选择 docker,则仅需配置 [docker-master] 和 [docker-node]
      # 如果是高可用集群,则需要在 [docker-master] 添加奇数个主机名
      [docker-master]
      kube01
      
      [docker-node]
      kube02
      
      [storage]
      kube01
      • 如果 cri 选择 containerd,则仅需配置 [containerd-master] 和 [containerd-node]
      # 如果是高可用集群,则需要在 [containerd-master] 添加奇数个主机名
      [containerd-master]
      kube01
      
      [containerd-node]
      kube02
      
      [storage]
      kube01
  4. 打通部署节点(运行 kubez-ansible 的节点) 到其他 node 节点的免密登陆 批量开启免密登陆

  5. 修改 /etc/kubez/globals.yml 配置文件

    修改 kube_release: 为指定 Kubernetes 版本
    kube_release: 1.23.17
    
    修改 image_repository: "" 为本地镜像仓库
    image_repository: "192.168.16.210:58001/pixiuio"
    
    修改 yum_baseurl: “” 为本地 yum 仓库地址
    yum_baseurl: "http://192.168.16.210:58000/repository/pixiuio-centos"
    
    修改 image_repository_container: “” 为本地 repository_container 仓库地址
    image_repository_container: "192.168.16.210:58001"
    
  6. 执行如下命令,进行 kubernetes 的依赖安装

    kubez-ansible -i multinode bootstrap-servers
  7. 根据实际需要,调整配置文件 /etc/kubez/globals.yml

    enable_kubernetes_ha: "yes"  # (可选)启用多控高可用, 需保证 multinode 的 control 组为奇数
    
    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"
  8. 执行如下命令,进行 kubernetes 的集群安装

    kubez-ansible -i multinode deploy
  9. 验证环境

    [root@kube01 ~]# kubectl get node
    NAME     STATUS   ROLES                  AGE     VERSION
    kube01   Ready    control-plane,master   21h     v1.23.17
    kube02   Ready    <none>                 21h     v1.23.17
    kube03   Ready    <none>                 3h48m   v1.23.17
  10. (可选)启用 kubectl 命令行补全

    kubez-ansible -i multinode post-deploy