百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

《蹲坑学Kubernetes》之:kubeadm部署Kubernetes-v1.18.6群集

nanshan 2024-10-16 10:51 10 浏览 0 评论

一、环境准备

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

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 = 1
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv6.conf.all.disable_ipv6 = 0
net.ipv6.conf.default.forwarding = 1
net.ipv6.conf.all.forwarding = 1
vm.swappiness=0
vm.overcommit_memory=1
vm.panic_on_oom=0
fs.inotify.max_user_watches=89100
fs.file-max=52706963
fs.nr_open=52706963
net.core.default_qdisc = fq
net.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 - $basearch
baseurl=https://download.docker.com/linux/centos/7/$basearch/stable
enabled=1
gpgcheck=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

三、安装 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=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=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

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

4、创建kubernetes集群

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

[root@k8s-master ~]# kubeadm config images list

(2)下载镜像

[root@k8s-master ~]# vim k8s-dowm-images.sh
添加:
## 使用如下脚本下载国内镜像,并修改tag为google的tag
set -e
KUBE_VERSION=v1.18.6
KUBE_PAUSE_VERSION=3.2
ETCD_VERSION=3.4.3-0
CORE_DNS_VERSION=1.6.7
 
GCR_URL=k8s.gcr.io
ALIYUN_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/$imageName
done
 
 
[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

(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(服务)网段(和微服务架构有关)

(4)确认kubelet服务

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

(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


(7)查看群集运行状态

[root@k8s-master ~]# kubectl get pods -n kube-system
[root@k8s-master ~]# kubectl get nodes

注释:

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
[root@k8s-master ~]# kubectl get pods -n kube-system -o wide
[root@k8s-master ~]# kubectl get pods -n kube-system -o wide | grep flannel

8、验证Flannel网络

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

[root@master ~]# ip a
[root@k8s-master ~]# ifconfig flannel.1


注:Flannel与cni0接口

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

[root@k8s-node-1 ~]# ip a
[root@k8s-node-1 ~]# ifconfig flannel.1  &&  ifconfig cni0

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

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

(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 <(kubectl completion bash)

2查看节点状态

(1)查看节点

[root@k8s-master ~]# kubectl get nodes
[root@k8s-master ~]# kubectl get nodes -o wide
[root@k8s-master ~]# kubectl get service --namespace=kube-system

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

[root@k8s-master ~]# kubectl version

到此,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:
[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: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kubernetes-dashboard
spec:
  type: NodePort                                ##添加type: NodePort,指定外部访问
  ports:
    - port: 443
      targetPort: 8443
      nodePort: 30000                          ##添加nodePort: 30000,指定访问端口。
  selector:
k8s-app: kubernetes-dashboard
 
……
image: kubernetesui/dashboard:v2.0.3
imagePullPolicy: IfNotPresent                           ##修改IfNotPresent
……

4、创建dashboard

[root@k8s-master ~]# kubectl apply -f   recommended.yaml
[root@k8s-master ~]# kubectl get pods --all-namespaces  -o wide
或者
[root@k8s-master ~]# kubectl get pods -n kubernetes-dashboard
[root@k8s-master ~]# kubectl get pods -n kubernetes-dashboard -o wide
[root@k8s-master ~]# kubectl get service --all-namespaces
或者
[root@k8s-master ~]# kubectl get service -n kubernetes-dashboard
[root@k8s-master ~]# kubectl describe service kubernetes-dashboard -n kubernetes-dashboard

5、创建管理员账号

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

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

# 绑定角色 cluster-admin

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

查找secret

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

6、获取dashboard-admin 的token值

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

7、客户端访问

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

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

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

登录成功后



相关推荐

MongoDB 从入门到实战:.NET 平台完整指南

一、什么是MongoDBMongoDB是一种功能强大且灵活的NoSQL数据库,适用于处理大规模的半结构化数据和高并发场景。它不依赖于固定的表结构和关系模型,而是以文档的形式存储数据,每个文档可...

NET Framework安装失败的原因及解决方法

大家好我是艾西,一个做服务器租用的游戏爱好者兼网络架构系统环境问题网络工具人。在我们平时使用PC安装某些程序会出现.NETFramework缺失的提示,那么也会有很多的小伙伴搞不懂什么原因导致的,这...

这可是全网eNSP安装最完整,最详细的图解,没有之一(常见问题)

eNSP安装大纲eNSP安装详细图解篇幅较长,会分三篇更完。急需安装的朋友可以在文末获取图解文档和所需软件工具。ENSP安装常见问题和解决方案Vbox安装错误eNSP在安装的过程当中,经常会出现一...

如何在windows 2012安装.NET Framework3.5

Windowsserver2012R2,自带的是.NETFramework4.5,如果想装SQLserver2008或者SQLserver2012需要安装.ENTFramework...

3款国内可用的「Chrome」扩展下载网站

身为程序员,有几个不使用Chrome浏览器提升下编码效率呢?Chrome拥有众多丰富强大的扩展程序,今天给大家分享三个国内可用的Chrome扩展下载网站,收藏一下吧,不然下次就找不到我咯!C...

下载 Windows 10 应用商店程序离线包方法

有厂商为了图方便,会把Windows10应用商店里面的UMP应用改成EXE程序版本。例如之前「网易云音乐」UMP版本简洁清爽,获得不少用户推荐,后来官方懒得更新了,直接把UMP版本...

极速安装!NET Framework 3.5零距离指南!

.NETFramework3.5是一款由微软开发的应用程序框架,它为许多Windows应用程序提供了基础支持。它的新版本带来了许多令人兴奋的功能和改进,比如增强的XML和JSON处理能力以及强大的...

Microsoft.NET离线运行库合集发布 2021

软件介绍.NET是微软具有战略意义的框架,也是装机必不可少的框架,想要一个一个安装略显繁琐,再加上很多电脑小白不知道怎么下载,不小心就下载到某某高速加载器,这个运行库极大解决了这个问题,采用微软官方....

缺少.net framework 3.5怎么办?(缺少.net4.5.1或以上环境)

很多电脑用户在玩某些程序游戏时都会遇到一个头痛的问题,弹出缺少“NETFramework3.5”的提示。微软从Windows8开始默认屏蔽了“.NET3.5”,如果用户有需要就必须选择在线安装...

Windows11无法正常安装.net 3.5组件的解决方法

最近因公司部分电脑升级至Windows11之后,重新安装某些需要加载.net3.5组件的应用软件时,都提示无法完成加载或安装.net3.5而导致无法完成安装。使用离线安装包亦一样无法完成安装。一...

离线安装.Net Framework 3.5(离线安装.net framework 4.0)

前言.Net3.5已经越来越少用到了,但是偶尔还是会遇到一些老软件需要。而Win10、Win11的系统,直接在控制面板的里添加,经常会添加失败!解决方法首先需要一个系统的ISO镜像来提取sxs文件夹:...

Jenkins 11个使用技巧,90%以上的人没用过

一、Performance插件兼容性问题自由风格项目中,有使用Performance插件收集构建产物,但是截至到目前最新版本(Jenkinsv2.298,Performance:v3.19),此...

6款Linux常用远程连接工具,你最中意哪一款?

点击上方头像关注我,每周上午09:00准时推送,每月不定期赠送技术书籍。本文2106字,阅读约需6分钟Hi,大家好。远程连接的实现方法有很多,概括地说有两种,一种是用系统自带的远程连接,另外一种是用...

Linux常用远程连接工具介绍,总有一款适合你

作为运维或者网工最常用就是ssh远程和远程桌面工具,本文就介绍几个常用的远程连接工具,你在用哪一款呢SecureCRT介绍:我觉得这个是最好的SSH工具,没有之一。SecureCRT支持SSH,同时支...

终极软路由网络设置,ESXi虚拟机安装iKuai+openWrt双路由系统

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:BigBubbleGum本文是软路由系列的第五篇,也是折腾时间最长的一篇,在ESXi下分别独立安装和使用iKuai和openWrt...

取消回复欢迎 发表评论: