zhuzhiyang / kubeadm-ha

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

🎉 项目受 kubeasz 启发,考虑使用二进制进行安装的童鞋可以参考这个项目。

kubeadm-ha 使用 kubeadm 进行高可用 kubernetes 集群搭建,利用 ansible-playbook 实现自动化安装,既提供一键安装脚本,也可以根据 playbook 分步执行安装各个组件。

LICENSE HitCount FOSSA Status

  • 集群特性: 不受国内网络限制、所有组件使用 kubelet 托管、多 Master 高可用、TLS 双向认证、自定义 TLS 证书有效期、RBAC 授权、支持 Network Policy

  • 相关组件及支持:

    组件 支持
    OS Ubuntu 16.04+, Debian 9, CentOS 7.4+, RedHat 7
    k8s v1.15.0
    etcd v3.3.10
    docker 18.06.3, 18.09.3, 18.09.6
    network flannel, calico, kube-ovn
    ingress-controller traefik, nginx-ingress

asciicast

1. 克隆本项目

  • 克隆本项目至任意节点中:

    git clone https://github.com/TimeBye/kubeadm-ha.git
    

2. Ansible 环境准备

  • 进入项目安装ansible运行需要的环境:

    sudo ./install-ansible.sh

3. 修改 hosts 文件

编辑项目example文件夹下的主机清单文件,修改各机器的访问地址、用户名、密码,并维护好各节点与角色的关系。文件中配置的用户必须是具有 root 权限的用户。项目预定义了6个例子,请修改后完成适合你的集群规划,生产环境建议一个节点只是一个角色。

  • 搭建集群后有以下两种“样式”显示,请自行选择:
    • 样式一

      NAME             STATUS    ROLES                    AGE    VERSION
      192.168.56.11    Ready     lb,etcd,master,worker    1d     v1.15.0
      192.168.56.12    Ready     lb,etcd,master,worker    1d     v1.15.0
      192.168.56.13    Ready     lb,etcd,master,worker    1d     v1.15.0
      
    • 样式二

      NAME     STATUS    ROLES                    AGE    VERSION
      node1    Ready     lb,etcd,master,worker    1d     v1.15.0
      node2    Ready     lb,etcd,master,worker    1d     v1.15.0
      node3    Ready     lb,etcd,master,worker    1d     v1.15.0
      
    • 对应的hosts配置文件事例如下:

      节点分配 样式一 样式二
      单节点 hosts.allinone.ip hosts.allinone.hostname
      单主多节点 hosts.s-master.ip hosts.s-master.hostname
      多主多节点 hosts.m-master.ip hosts.m-master.hostname

4. 部署

一句命令拥有一个高可用 kubernetes 集群:

  • 基本配置执行

    ansible-playbook -i example/hosts.m-master.ip.ini 90-init-cluster.yml
    
  • 高级配置执行

    ansible-playbook -i example/hosts.m-master.ip.ini -e @example/variables.yaml 90-init-cluster.yml
    

example/hosts.m-master.ip.ini文件中与example/variables.yaml参数冲突,则以example/variables.yaml文件为准。

5. 重置集群

  • 如果部署失败,想要重置集群(所有数据),执行:

    ansible-playbook -i example/hosts.m-master.ip.ini 99-reset-cluster.yml
    

6. 升级集群

  • 升级kubernetes版本,执行:

    # 请注意替换用下面命令中版本号x部分为实际版本
    ansible-playbook -i example/hosts.m-master.ip.ini -e kube_upgrade_version=1.15.x 96-upgrade-cluster.yml
    

License

FOSSA Status

About

License:Other


Languages

Language:Shell 97.0%Language:Dockerfile 3.0%