文章目录

  • 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管理页面。

k8s 集群重启docker k8s集群关机顺序_k8s 集群重启docker


可以看到rancher的引导信息,提示需要进行如下操作,按照提示操作即可

# 找到容器ID
docker ps
# 找到容器对应的密码
docker logs  ${container-id}  2>&1 | grep "Bootstrap Password:"

k8s 集群重启docker k8s集群关机顺序_k8s 集群重启docker_02


将密码输入到对话框里,点击“Log in with Local User”。在下表面的页面填写好新密码和Server URL,然后点击Continue。

注意:

密码至少12位

Server URL一定要填写IP地址

k8s 集群重启docker k8s集群关机顺序_kubernetes_03

可以在左侧设置语言

k8s 集群重启docker k8s集群关机顺序_docker_04

6. 创建k8s集群

点击创建

k8s 集群重启docker k8s集群关机顺序_rancher_05


选择自定义

k8s 集群重启docker k8s集群关机顺序_kubernetes_06


输入集群名字,选择版本

k8s 集群重启docker k8s集群关机顺序_云原生_07


在“Advanced Options”中进行高级设置,比如:选择是否启用Nginx Ingress,我这里没有选择没有开启。这个设置项后续可以点击rancher界面中此集群的升级按钮进行重新选择。

k8s 集群重启docker k8s集群关机顺序_rancher_08


点击“Next”后,进入添加主机命令页面

k8s 集群重启docker k8s集群关机顺序_云原生_09


点选Etcd,Control Plan两个选项,最好把Worker选项也选上,然后复制下方的命令,到master1节点执行,这里没有选择Worker。如果部署的是多个master节点的集群,只要把对应的命令在每一台master节点上执行就可以。

点选Worker选项,然后复制下方的命令,到2个node节点执行。

k8s 集群重启docker k8s集群关机顺序_kubernetes_10


当集群前面的状态变成Active时,就表示集群部署完成。

k8s 集群重启docker k8s集群关机顺序_云原生_11


可以点击集群的名称,进入集群详情页

k8s 集群重启docker k8s集群关机顺序_rancher_12


点击箭头处的标识,可以下载集群的配置文件保存。在k8s-rancher服务器上创建文件夹.kube,并在此文件夹下创建config文件,将下载的配置文件内容复制进去,保存退出,

k8s 集群重启docker k8s集群关机顺序_docker_13


然后在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

k8s 集群重启docker k8s集群关机顺序_kubernetes_14


到这里,rancher部署单master节点的k8s集群就完成了。整体下来给我的感觉就是方便,不用再修改配置文件,也不用再去找错误了,大大的缩短了部署集群的时间。在可视化平台上只需要点一点,集群就轻松部署完成了非常方便。