魔改自阿良老师的项目 https://github.com/lizhenliang/ansible-install-k8s
- 修改了一些镜像的地址为国内能下载到的源
- 新增了对Debian系列的支持
- 升级k8s版本至1.29.12(实际支持的版本范围1.23.x-1.32.x)
- 将离线版安装方式改为在线版,摆脱对百度云的依赖
- 支持k8s安装版本选择功能
- 新增节点时间同步的定时任务
- 新增ETCD数据备份的定时任务
- 新增清理集群日志的定时任务,避免磁盘压力
# yum install epel-release -y
# yum install ansible -y
或
# apt-get install ansible -y
下载Ansible部署文件:
# git clone https://github.com/leif160519/ansible-install-k8s
# cd ansible-install-k8s
修改hosts文件,根据规划修改对应IP和名称。
# vim inventory/hosts
...
修改group_vars/all.yml文件,修改k8s版本,软件包目录和证书可信任IP。
# vim group_vars/all.yml
k8s_version: 1.29.12
...
cert_hosts:
k8s:
etcd:
- 单Master架构
- 多Master架构
单Master版:
# ansible-playbook playbooks/single-master-deploy.yml
多Master版:
# ansible-playbook playbooks/multi-master-deploy.yml
# kubectl get node
NAME STATUS ROLES AGE VERSION
k8s-master-01 Ready <none> 54m v1.29.12
k8s-master-02 Ready <none> 54m v1.29.12
k8s-node-01 Ready <none> 54m v1.29.12
k8s-node-02 Ready <none> 54m v1.29.12
k8s-node-03 Ready <none> 54m v1.29.12
如果安装某个阶段失败,可针对性测试.
例如:只运行部署插件
# ansible-playbook playbooks/single-master-deploy.yml -t addons
1)修改hosts,添加新节点ip
# vi hosts
...
[newnode]
192.168.31.85 node_name=k8s-node-04
2)执行部署
# ansible-playbook playbooks/add-node.yml
部署产生的证书都会存放到目录“ansible-install-k8s/playbooks/ssl”,一定要保存好,后面还会用到~
清排查本地dns配置:
cat /etc/resolv.conf
若返回的结果有127.0.0.53
,则需要额外执行一个配置:
ansible-playbook playbooks/single-master-deploy.yml -t docker
执行完成之后,再次检查dns配置,显示如下内容代表正常,此时coredns会自动恢复正常,若不能自动回复,删除pod之后集群会自动生成一个新的pod
nameserver 114.114.114.114
nameserver 223.5.5.5
search localdomain
在playbooks/muti-master-deploy.yml
或者playbooks/single-master-deploy.yml
中添加如下代理环境变量的配置即可
...略
- name: 4.部署K8S Master
hosts: master
environment: # 添加环境变量配置
HTTP_PROXY: http://xx.xx.xx.xx:3128 # 配置http_proxy环境变量
HTTPS_PROXY: http://xx.xx.xx.xx:3128 # 配置https_proxy环境变量
roles:
- node
tags: node
...略
端口可能会略有差异,有的可能是7890等
欢迎clone和star我的项目:k8s-deploy
选择
kubernetes-client-linux-amd64.tar.gz
下载即可