群集服务验证失败_《蹲坑学Kubernetes》之:kubeadm部署Kubernetes-v1.18.6群集

20d641153e45f689ac64b06aca7c0c7d.gif

一、环境准备

注意:在k8-smaster、k8s-node-1和k8s-node-2进行准备工作配置。

39d77ff4dd64452ae27063a03133516f.png

1、内核升级

[root@k8s-master ~]# rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org[root@k8s-master ~]# rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm[root@k8s-master ~]# yum -y update[root@k8s-master ~]# yum --enablerepo=elrepo-kernel install kernel-ml kernel-ml-devel -y[root@k8s-master ~]# cat /boot/grub2/grub.cfg | grep menuentry[root@k8s-master ~]# grub2-set-default "CentOS Linux (5.4.3-1.el7.elrepo.x86_64) 7 (Core)"[root@k8s-master ~]# grub2-editenv list

2、关闭防火墙

[root@k8s-master ~]# systemctl stop firewalld.service[root@k8s-master ~]# systemctl disable firewalld.service

3、关闭 Swap

[root@k8s-master ~]#swapoff -a#要永久禁掉swap分区,打开如下文件注释掉swap那一行[root@k8s-master ~]# vim /etc/fstab

4、关闭 SELinux

[root@k8s-master ~]# vim /etc/selinux/config修改:SELINUX=disable

5、配置转发参数

[root@k8s-master ~]# vim /etc/sysctl.d/k8s.conf添加:net.ipv4.ip_forward = 1net.bridge.bridge-nf-call-ip6tables = 1net.bridge.bridge-nf-call-iptables = 1net.ipv6.conf.all.disable_ipv6 = 0net.ipv6.conf.default.forwarding = 1net.ipv6.conf.all.forwarding = 1vm.swappiness=0vm.overcommit_memory=1vm.panic_on_oom=0fs.inotify.max_user_watches=89100fs.file-max=52706963fs.nr_open=52706963net.core.default_qdisc = fqnet.ipv4.tcp_congestion_control = bbr [root@k8s-master ~]# modprobe bridge && modprobe br_netfilter[root@k8s-master ~]# sysctl -p

二、安装docker-ce-19

注意:在k8-smaster、k8s-node-1、k8s-node-2安装Docker。

[root@k8s-master ~]# vim /etc/yum.repos.d/docker.repo添加:[docker]name=Docker CE Stable - $basearchbaseurl=https://download.docker.com/linux/centos/7/$basearch/stableenabled=1gpgcheck=0 [root@k8s-master ~]# yum -y install docker-ce[root@k8s-master ~]# systemctl enable docker.service[root@k8s-master ~]# systemctl start docker.service[root@k8s-master ~]# systemctl status docker.service[root@k8s-master ~]# docker info
4a8308278b02d20702c69882656c46d8.png

三、安装 Kubeadm:v1.18.6

注意:在k8-smaster、k8s-node-1和k8s-node-2中安装Kubeadm。

1、安装ipvsadm模块

[root@k8s-master ~]# yum install ipvsadm ipset -y[root@k8s-master ~]# modprobe -- ip_vs modprobe -- ip_vs_rr modprobe -- ip_vs_wrr modprobe -- ip_vs_sh modprobe -- nf_conntrack_ipv4[root@k8s-master ~]# lsmod |egrep ip_vs

2、安装Kubeadm

[root@k8s-master ~]# vim /etc/yum.repos.d/kubernetes.repo[kubernetes]name=Kubernetesbaseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64enabled=1gpgcheck=0 [root@k8s-master ~]# yum -y install epel-release [root@k8s-master ~]# yum clean all[root@k8s-master ~]# yum makecache  下面就开始正式安装 Kubeadm 了:[root@k8s-master ~]# yum -y install kubelet kubeadm kubectl                   #默认安装最新版本

3、启动kubelet服务

[root@k8s-master ~]# systemctl enable kubelet.service[root@k8s-master ~]# systemctl start kubelet.service[root@k8s-master ~]# systemctl status kubelet.service
1fb7e32b7b03622a1f232d09c09035b2.png

注意:此时kubelet.service服务是不会启动的,等到kubelet.service初始化后才会启动。

4、创建kubernetes集群

(1)查看该版本的容器镜像版本

[root@k8s-master ~]# kubeadm config images list
64d20573c0742c143a053d7e3f9421ba.png

(2)下载镜像

[root@k8s-master ~]# vim k8s-dowm-images.sh添加:## 使用如下脚本下载国内镜像,并修改tag为google的tagset -eKUBE_VERSION=v1.18.6KUBE_PAUSE_VERSION=3.2ETCD_VERSION=3.4.3-0CORE_DNS_VERSION=1.6.7 GCR_URL=k8s.gcr.ioALIYUN_URL=registry.cn-hangzhou.aliyuncs.com/google_containers images=(kube-proxy:${KUBE_VERSION}kube-scheduler:${KUBE_VERSION}kube-controller-manager:${KUBE_VERSION}kube-apiserver:${KUBE_VERSION}pause:${KUBE_PAUSE_VERSION}etcd:${ETCD_VERSION}coredns:${CORE_DNS_VERSION}) for imageName in ${images[@]} ; do  docker pull $ALIYUN_URL/$imageName  docker tag  $ALIYUN_URL/$imageName $GCR_URL/$imageName  docker rmi $ALIYUN_URL/$imageNamedone  [root@k8s-master ~]# chmod +x k8s-dowm-images.sh[root@k8s-master ~]# ./k8s-dowm-images.sh或者输入下载命令下载镜像[root@k8s-master ~]# kubeadm config images pull [root@k8s-master ~]# docker images
b64cfedbb7a8b7e7cdb67581131b57b4.png

(3)初始化kubernetes集群

注意:在k8-smaster中进行初始化操作。

[root@k8s-master ~]# kubeadm init --kubernetes-version=v1.18.6 --apiserver-advertise-address=192.168.1.3 --pod-network-cidr=10.244.0.0/16 --service-cidr=10.0.0.0/12注释: --kubernetes-version=v1.18.6 : 加上该参数后启动相关镜像--pod-network-cidr=10.244.0.0/16 :(Pod 中间网络通讯我们用flannel,与flannel保持一致,这个IP段就是Pod的IP段)--service-cidr=10.0.0.0/12 : Service(服务)网段(和微服务架构有关)
6ae027bdd5e5843fbc14fd360029528c.png

(4)确认kubelet服务

[root@k8s-master ~]# systemctl status kubelet.service
89bde0e00a14322c3a8416a3fa03d99e.png
[root@k8s-master ~]# netstat -anpt | grep kubelet
ed7a9575009c3d81229206899a2ed5c9.png

(5)配置kubectl认证信息

[root@k8s-master ~]# mkdir -p $HOME/.kube[root@k8s-master ~]# cp -i /etc/kubernetes/admin.conf $HOME/.kube/config[root@k8s-master ~]# chown $(id -u):$(id -g) $HOME/.kube/config

(6)将node节点加入Kubernetes群集

查看token[root@k8s-master ~]# kubeadm token list可以使用命令来获取token[root@k8s-master ~]# kubeadm token create --print-join-command 

将node节点加入群集

注意:在k8-node-1和k8-node-2中进行操作。

[root@k8s-node-1 ~]# kubeadm join 192.168.1.3:6443 --token rkaf1i.y7m2u7z068tgw7os     --discovery-token-ca-cert-hash sha256:09d6bd168550b25e30a43e7bda6db0ad650840d0ce5aa342e7c72b03d3805dc3 [root@k8s-node-2 ~]# kubeadm join 192.168.1.3:6443 --token rkaf1i.y7m2u7z068tgw7os     --discovery-token-ca-cert-hash sha256:09d6bd168550b25e30a43e7bda6db0ad650840d0ce5aa342e7c72b03d3805dc3
8aff2ffa5db2f343c1daddb491b2149d.png

(7)查看群集运行状态

[root@k8s-master ~]# kubectl get pods -n kube-system
a2edc6e77ceee3d5f03e2d2bb9649884.png
[root@k8s-master ~]# kubectl get nodes
2395e4e014827dcb11e5818f76653c49.png

注释:

NotReady:未准备好。原因是没有配置网络。

四、设置flannel网络

注意:在k8s-master、k8-node-1和k8-node-2中部署Flannel网络。

1、下载cni软件

[root@k8s-master ~]# wget https://github.com/containernetworking/plugins/releases/download/v0.8.6/cni-plugins-linux-amd64-v0.8.6.tgz

2、部署cni

[root@k8s-master ~]# mkdir /opt/cni/bin -p[root@k8s-master ~]# tar zxvf cni-plugins-linux-amd64-v0.8.6.tgz -C /opt/cni/bin

3、下载配置文件

[root@k8s-master ~]# wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

4、下载镜像

[root@k8s-master ~]# docker pull quay.io/coreos/flannel:v0.12.0-amd64

5、配置flannel配置文件

[root@k8s-master ~]# vim kube-flannel.yml修改:      "Network": "10.244.0.0/16", ##注意与master初始化保持一致。--pod-network-cidr=10.244.0.0/16      "Backend": {        "Type": "vxlan"      }……“name”: “cbr0”,      “cniVersion”: “0.3.1”,                   ##添加此行,确保pod之间能够通信。

6、创建flannel资源

[root@k8s-master ~]# kubectl apply -f kube-flannel.yml

7、查看flannel的Pod

[root@k8s-master ~]# kubectl get pods -n kube-system
dfe2840c20ba08448d6890724f2c4c57.png
[root@k8s-master ~]# kubectl get pods -n kube-system -o wide
d1645a7d80e1de565572600d5316c29a.png
[root@k8s-master ~]# kubectl get pods -n kube-system -o wide | grep flannel
82124d2578b974f0cbbb7ac271af6b6a.png

8、验证Flannel网络

(1)在master上查看ip地址状态

[root@master ~]# ip a
cd300c609c1906517ae124b03deb9bc9.png
[root@k8s-master ~]# ifconfig flannel.1
303f01032d147e427f98bef4d8f5bb90.png

注:Flannel与cni0接口

(2)在node-1上查看ip地址状态

[root@k8s-node-1 ~]# ip a
62b2840a54b3b6b0a578b18d625657fe.png
[root@k8s-node-1 ~]# ifconfig flannel.1  &&  ifconfig cni0
31692b6573930b8490ae15a292254fdd.png

(3)在node-2上查看ip地址状态

[root@k8s-node-2 ~]# ip a
db8f966cc69d749a9aba3528b2a3434d.png
[root@k8s-node-2 ~]# ifconfig flannel.1  &&  ifconfig cni0
96981bdecceb1ac598edb65c114c427c.png

(4)检查通信状况

注:ping Node节点中cni的IP,能通信为正常!

[root@k8s-master ~]# ping 10.244.1.1[root@k8s-master ~]# ping 10.244.2.1

五、Kubernetes群集测试

1、设置命令行自动补全功能

[root@k8s-master ~]# source /usr/share/bash-completion/bash_completion[root@k8s-master ~]# source 

2查看节点状态

(1)查看节点

[root@k8s-master ~]# kubectl get nodes
68739d81ebe10e1fcd737f6db49887ae.png
[root@k8s-master ~]# kubectl get nodes -o wide
af873177c8b9743d65be97954e9bc859.png
[root@k8s-master ~]# kubectl get service --namespace=kube-system
1f6da4155679314d00b8fa61084bc7f2.png

(2)输出client 和server的版本信息

[root@k8s-master ~]# kubectl version
3cf507be4b07ba76ea8a0bb384892e99.png

到此,kubernetes群集部署完毕!

六、安装kubernetes1.18.6的web-ui端:

1、下载dashboard配置文件

[root@k8s-master ~]# wget https://raw.githubusercontent.com/kubernetes/dashboard/v2.0.3/aio/deploy/recommended.yaml

2、下载镜像

[root@k8s-master ~]# cat recommended.yaml | grep image:
2cff9f5183a9d7358802e3369070d9b7.png
[root@k8s-master ~]# docker pull kubernetesui/dashboard:v2.0.3[root@k8s-master ~]# docker pull kubernetesui/metrics-scraper:v1.0.4

3、修改配置文件

[root@k8s-master ~]# vim recommended.yaml##为了方便访问,修改kubernetes-dashboard的Service定义,指定Service的type类型为NodeType,指定nodePort端口添加:kind: ServiceapiVersion: v1metadata:  labels:    k8s-app: kubernetes-dashboard  name: kubernetes-dashboard  namespace: kubernetes-dashboardspec:  type: NodePort                                ##添加type: NodePort,指定外部访问  ports:    - port: 443      targetPort: 8443      nodePort: 30000                          ##添加nodePort: 30000,指定访问端口。  selector:k8s-app: kubernetes-dashboard ……image: kubernetesui/dashboard:v2.0.3imagePullPolicy: IfNotPresent                           ##修改IfNotPresent……

4、创建dashboard

[root@k8s-master ~]# kubectl apply -f   recommended.yaml
e615a7d64e94bc3ab8589b7775c5d121.png
[root@k8s-master ~]# kubectl get pods --all-namespaces  -o wide或者[root@k8s-master ~]# kubectl get pods -n kubernetes-dashboard
f8d71f6d7caeee422bbb6a3ce4011abf.png
[root@k8s-master ~]# kubectl get pods -n kubernetes-dashboard -o wide
9e84173b732f6615c65921e681edcc55.png
[root@k8s-master ~]# kubectl get service --all-namespaces或者[root@k8s-master ~]# kubectl get service -n kubernetes-dashboard
2fad4d2988a50eeed81d27e99191425e.png
[root@k8s-master ~]# kubectl describe service kubernetes-dashboard -n kubernetes-dashboard
0cf414e73875e01ebb07be2a75308127.png

5、创建管理员账号

创建一个专用的 serviceaccount 帐号 dashboard-admin

[root@k8s-master ~]# kubectl create serviceaccount dashboard-admin -n kube-system
14e53a1b8d3d49c6ed73dd8e61cf98c1.png

# 绑定角色 cluster-admin

[root@k8s-master ~]# kubectl create clusterrolebinding dashboard-cluster-admin --clusterrole=cluster-admin --serviceaccount=kube-system:dashboard-admin
a4ad4dea9e12fcbc383b1dbd8901573a.png
[root@k8s-master ~]# kubectl get sa -n kube-system
4264db1f082e1f4783ada9f7a8636e19.png
[root@k8s-master ~]# kubectl describe serviceaccount dashboard-admin -n kube-system
ff84edf1ce7ade45f8abc2bfa9a1fe8e.png

查找secret

[root@k8s-master ~]# kubectl get secret  --all-namespaces
bbc5144ef5389a60bb1b9a3b75c8f660.png

6、获取dashboard-admin 的token值

[root@k8s-master ~]# kubectl describe secret dashboard-admin-token-lbvpl -n kube-system
fecdba9afcd750b06ed88c016d255691.png

7、客户端访问

[root@k8s-node-1 ~]# firefox https://192.168.1.1:30000/ &

首次方式需要添加安全例外。

cf7a11de2e1c88efa086e027b5212445.png

使用Token认证登录,将之前查询的Token值复制粘贴过来即可。

1c500bbac4f4062ef917e383299e2631.png

登录成功后

352e56ed602ba4b5f9d1f525da6bd9b3.png
416ab9f6ad82ceca2349361ea9e87740.png

642a7817b5bf5e7af04a917b7623fc13.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值