文章目录
- 1. 准备工作
- 2. 初始化操作
- 2.1 关闭防火墙
- 2.2 关闭selinux
- 2.3 关闭swap分区
- 2.4 设置主机名
- 2.5 修改hosts表
- 2.6 时间同步
- 2.7 流量转发
- 3. 部署docker
- 4. 部署rancher
- 5. 配置rancher
- 6. 创建k8s集群
整体思路:
首先,准备好4台服务器,并且固定好IP;其次将4台服务器初始化,并在4台服务器上安装docker;然后在rancher节点的服务器上安装rancher,安装成功过后就可以通过IP+端口号访问rancher页面进行可视化操作了;最后在rancher节点服务器上创建配置文件,部署kubectl,就可以通过rancher节点控制整个集群了。
1. 准备工作
准备了4台机器,一台rancher,一台master,2台node,固定好IP,可以参考这篇文章,帮助您固定虚拟机IP(此处有超链接)
主机名称 | IP | 部署内容 | 组件 |
k8s-rancher | 192.168.2.21 | rancher | docker\rancher\kubectl |
k8s-master1 | 192.168.2.22 | master1 | docker |
k8s-node1 | 192.168.2.23 | node1 | docker |
k8s-node2 | 192.168.2.24 | node2 | docker |
2. 初始化操作
2.1 关闭防火墙
systemctl disable firewalld #永久关闭,移除开机自启项,以后开机不会启动
systemctl stop firewalld #临时关闭,立刻关闭
2.2 关闭selinux
sed -i 's/enforcing/disabled/' /etc/selinux/config # 修改selinux配置文件为关闭状态,以后开机不会启动
setenforce 0 #临时关闭,立刻关闭
2.3 关闭swap分区
sed -ri 's/.*swap.*/#&/' /etc/fstab # 修改swap配置文件为关闭状态,以后开机不会启动
swapoff -a #临时关闭,立刻关闭
2.4 设置主机名
hostnamectl set-hostname <设定的主机名称>
bash # 刷新
2.5 修改hosts表
cat >> /etc/hosts << EOF
192.168.2.21 k8s-rancher
192.168.2.22 k8s-master1
192.168.2.23 k8s-node1
192.168.2.24 k8s-node2
EOF
2.6 时间同步
yum -y install ntpdate
ntpdate time.windows.com
2.7 流量转发
# 将桥接的 IPv4 流量传递到 iptables 的链
cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
cat >> /etc/sysctl.conf<<EOF
net.ipv4.ip_forward=1
net.bridge.bridge-nf-call-iptables=1
net.ipv4.neigh.default.gc_thresh1=4096
net.ipv4.neigh.default.gc_thresh2=6144
net.ipv4.neigh.default.gc_thresh3=8192
EOF
#加载
modprobe br_netfilter
sysctl -p
sysctl --system # 生效
3. 部署docker
安装之前确保没有其他dockers版本,如果有别的版本会有冲突,需要把原有的卸载再安装,可以参考这篇文章,卸载dockers(此处有超链接) 在4台服务器即所有节点上部署。
# 下载docker的yum源
wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
# 安装docker,找上一步的yum源去安装
yum -y install docker-ce-20.10.12-3.el7
# 开机自启动并且启动docker
systemctl enable docker && systemctl start docker
# 查看docker版本
docker --version
# 设置docker拉取镜像的加速器
cat > /etc/docker/daemon.json << EOF
{
"registry-mirrors": ["https://b9pmyelo.mirror.aliyuncs.com"]
}
EOF
# 重启docker
systemctl daemon-reload
systemctl restart docker
4. 部署rancher
在k8s-rancher服务器上部署rancher,这里部署的是2.6版本
docker run -d --restart=unless-stopped -p 8080:80 -p 8443:443 --privileged rancher/rancher:v2.6.3
5. 配置rancher
完成后,访问https://<部署主机的ip>:8443 ,进入rancher管理页面。
可以看到rancher的引导信息,提示需要进行如下操作,按照提示操作即可
# 找到容器ID
docker ps
# 找到容器对应的密码
docker logs ${container-id} 2>&1 | grep "Bootstrap Password:"
将密码输入到对话框里,点击“Log in with Local User”。在下表面的页面填写好新密码和Server URL,然后点击Continue。
注意:
密码至少12位
Server URL一定要填写IP地址
可以在左侧设置语言
6. 创建k8s集群
点击创建
选择自定义
输入集群名字,选择版本
在“Advanced Options”中进行高级设置,比如:选择是否启用Nginx Ingress,我这里没有选择没有开启。这个设置项后续可以点击rancher界面中此集群的升级按钮进行重新选择。
点击“Next”后,进入添加主机命令页面
点选Etcd,Control Plan两个选项,最好把Worker选项也选上,然后复制下方的命令,到master1节点执行,这里没有选择Worker。如果部署的是多个master节点的集群,只要把对应的命令在每一台master节点上执行就可以。
点选Worker选项,然后复制下方的命令,到2个node节点执行。
当集群前面的状态变成Active时,就表示集群部署完成。
可以点击集群的名称,进入集群详情页
点击箭头处的标识,可以下载集群的配置文件保存。在k8s-rancher服务器上创建文件夹.kube
,并在此文件夹下创建config
文件,将下载的配置文件内容复制进去,保存退出,
然后在k8s-rancher服务器部署kubectl命令,就可以通过kubectl命令控制集群了。
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
yum install -y kubectl
查看节点状态
kubectl get nodes
到这里,rancher部署单master节点的k8s集群就完成了。整体下来给我的感觉就是方便,不用再修改配置文件,也不用再去找错误了,大大的缩短了部署集群的时间。在可视化平台上只需要点一点,集群就轻松部署完成了非常方便。