当前位置:   article > 正文

kubeadmin搭建自建k8s集群_下载flannel.yml

下载flannel.yml

一、安装要求

在开始之前,部署Kubernetes集群的虚拟机需要满足以下几个条件:

  1. 操作系统 CentOS7.x-86_x64
  2. 硬件配置:2GB或更多RAM,2个CPU或更多CPU,硬盘30GB或更多【注意master需要两核】
  3. 可以访问外网,需要拉取镜像,如果服务器不能访问外网,需要提前下载镜像包并导入节点服务器中(网上还有其他可用的国内镜像,但是我尝试过容易出现一些问题,所以我就干脆直接按照官网要求下载对应的镜像文件)
  4. 禁止swap分区

二、环境准备

mac 上安装虚拟机软件:VMware Fusion 12

centos7镜像:CentOS-7-x86_64-DVD-2207-02.iso

三台centos7虚拟机(配置静态 IP,防止 IP 的变化

节点

ip地址

master

192.168.2.128

work node1

192.168.2.129

work node2

192.168.2.130

三、操作步骤

1、依次在每台虚拟机上将下列指令均执行一遍

  1. 1 # 关闭防火墙
  2. 2 systemctl stop firewalld
  3. 3 systemctl disable firewalld
  4. 4
  5. 5 # 关闭selinux
  6. 6 # 永久关闭
  7. 7 sed -i 's/enforcing/disabled/' /etc/selinux/config
  8. 8 # 临时关闭
  9. 9 setenforce 0
  10. 10
  11. 11 # 关闭swap
  12. 12 # 临时
  13. 13 swapoff -a
  14. 14 # 永久关闭
  15. 15 sed -ri 's/.*swap.*/#&/' /etc/fstab
  16. 16 #修改主机名并且做域名解析
  17. 17 # 根据规划设置主机名【master节点上操作】
  18. 18 hostnamectl set-hostname k8smaster
  19. 19 # 根据规划设置主机名【node1节点操作】
  20. 20 hostnamectl set-hostname k8snode1
  21. 21 # 根据规划设置主机名【node2节点操作】
  22. 22 hostnamectl set-hostname k8snode2
  23. 23
  24. 24 # 在master添加hosts
  25. 25 cat >> /etc/hosts << EOF
  26. 26 192.168.2.128 k8smaster
  27. 27 192.168.2.129 k8snode1
  28. 28 EOF
  29. 29
  30. 30
  31. 31 # 将桥接的IPv4流量传递到iptables的链
  32. 32 cat > /etc/sysctl.d/k8s.conf << EOF
  33. 33 net.bridge.bridge-nf-call-ip6tables = 1
  34. 34 net.bridge.bridge-nf-call-iptables = 1
  35. 35 EOF
  36. 36 # 生效
  37. 37 sysctl --system
  38. 38
  39. 39 # 时间同步
  40. 40 yum install ntpdate -y
  41. 41 ntpdate time.windows.com

 2、安装Docker/kubeadm/kubelet/kubectl

所有节点安装Docker/kubeadm/kubelet ,Kubernetes默认CRI(容器运行时)为Docker,因此先安装Docker

2.1、安装Docker 

1)配置docker 的阿里yum源

  1. 1 cat >/etc/yum.repos.d/docker.repo<<EOF
  2. 2 [docker-ce-edge]
  3. 3 name=Docker CE Edge - \$basearch
  4. 4 baseurl=https://mirrors.aliyun.com/docker-ce/linux/centos/7/\$basearch/edge
  5. 5 enabled=1
  6. 6 gpgcheck=1
  7. 7 gpgkey=https://mirrors.aliyun.com/docker-ce/linux/centos/gpg
  8. 8 EOF

 2)yum安装docker

  1. 1 # yum安装
  2. 2 yum -y install docker-ce
  3. 3
  4. 4 # 查看docker版本
  5. 5 docker --version
  6. 6
  7. 7 # 启动docker
  8. 8 systemctl enable docker
  9. 9 systemctl start docker

 3)配置docker的镜像源

  1. 1 cat >> /etc/docker/daemon.json << EOF
  2. 2 {
  3. 3 "registry-mirrors": ["https://b9pmyelo.mirror.aliyuncs.com"]
  4. 4 }
  5. 5 EOF

 4)重启docker

1 systemctl restart docker

 2.2、添加kubernetes软件yum源

  1. 1 cat > /etc/yum.repos.d/kubernetes.repo << EOF
  2. 2 [kubernetes]
  3. 3 name=Kubernetes
  4. 4 baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
  5. 5 enabled=1
  6. 6 gpgcheck=0
  7. 7 repo_gpgcheck=0
  8. 8 gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
  9. 9 EOF
2.3、安装kubeadm,kubelet和kubectl
  1. 1 # 安装kubelet、kubeadm、kubectl,同时指定版本
  2. 2 yum install -y kubelet-1.18.0 kubeadm-1.18.0 kubectl-1.18.0
  3. 3 # 设置开机启动
  4. 4 systemctl enable kubelet

3、部署master节点

1)在master 节点上执行kubeadm init

  1. 1 # 参数解释:
  2. 2 # --image-repository 指定拉取kubernetes所需组件的镜像仓库
  3. 3 # --pod-network-cidr 设置pod的地址段
  4. 4 kubeadm init --apiserver-advertise-address=192.168.2.128 --image-repository registry.aliyuncs.com/google_containers --kubernetes-version=1.18.0 --pod-network-cidr=10.244.0.0/16

注意参数 --pod-network-cidr这个参数值的设置可以是192.168.0.0,或者是10.244.0.0,这个值会在后面的配置网络插件kube-flannel.yml中需要与之对应,很重要,否则会导致flannel pod启动失败,可能出现如下图错误

2)出现如下提示即代码 kubeadm init 执行成功

3)按照提示执行如下指令

  1. 1 mkdir -p $HOME/.kube
  2. 2 sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
  3. 3 sudo chown $(id -u):$(id -g) $HOME/.kube/config

 4)查看master节点状态,为NotReady

kubectl get nodes

4、部署Slave节点(以node1节点为例)

1)在node1节点下输入kubeadm init 执行成功后输出的指令kubeadm join xxxxx

  1. 1 kubeadm join 192.168.2.128:6443 --token 2p3p1k.iqoylq7ysjzph6ch \
  2. 2 --discovery-token-ca-cert-hash sha256:ff50efea2f2a2679e7xxxxxxxxxxxxxxx7770931434ed5b2f9f1ea1

2)上述token具有有效期,到期后需要使用如下指令重新生成token

kubeadm token create --print-join-command

5、部署CNI网络插件Flannel

1)kube-flannel.yml文件下载

每个节点上都需要下载如下镜像到本地仓库!!

2)kube-flannel.yml文件中所用到的docker镜像均需要下载后导入到本地镜像仓库中(每一个节点都需要执行操作!! 

3)执行如下命令生成flannel pod,联通节点之间的网络

  1. 1 [root@k8smaster ~]# kubectl create -f kube-flannel.yml
  2. 2 namespace/kube-flannel created
  3. 3 clusterrole.rbac.authorization.k8s.io/flannel created
  4. 4 clusterrolebinding.rbac.authorization.k8s.io/flannel created
  5. 5 serviceaccount/flannel created
  6. 6 configmap/kube-flannel-cfg created
  7. 7 daemonset.apps/kube-flannel-ds created

 4)执行上述命令后查看pods,nodes的状态(至此,集群搭建完成!)

  1. kubectl get nodes
  2. kubectl get pods

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号