《蹲坑学Kubernetes》之:kubeadm部署Kubernetes-v1.18.6群集
nanshan 2024-10-16 10:51 8 浏览 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值复制粘贴过来即可。
登录成功后
相关推荐
- 服务器数据恢复—Raid5数据灾难不用愁,Raid5数据恢复原理了解下
-
Raid5数据恢复算法原理:分布式奇偶校验的独立磁盘结构(被称之为raid5)的数据恢复有一个“奇偶校验”的概念。可以简单的理解为二进制运算中的“异或运算”,通常使用的标识是xor。运算规则:若二者值...
- 服务器数据恢复—多次异常断电导致服务器raid不可用的数据恢复
-
服务器数据恢复环境&故障:由于机房多次断电导致一台服务器中raid阵列信息丢失。该阵列中存放的是文档,上层安装的是Windowsserver操作系统,没有配置ups。因为服务器异常断电重启后,rai...
- 服务器数据恢复-V7000存储更换磁盘数据同步失败的数据恢复案例
-
服务器数据恢复环境:P740+AIX+Sybase+V7000存储,存储阵列柜上共12块SAS机械硬盘(其中一块为热备盘)。服务器故障:存储阵列柜中有磁盘出现故障,工作人员发现后更换磁盘,新更换的磁盘...
- 「服务器数据恢复」重装系统导致XFS文件系统分区丢失的数据恢复
-
服务器数据恢复环境:DellPowerVault系列磁盘柜;用RAID卡创建的一组RAID5;分配一个LUN。服务器故障:在Linux系统层面对LUN进行分区,划分sdc1和sdc2两个分区。将sd...
- 服务器数据恢复-ESXi虚拟机被误删的数据恢复案例
-
服务器数据恢复环境:一台服务器安装的ESXi虚拟化系统,该虚拟化系统连接了多个LUN,其中一个LUN上运行了数台虚拟机,虚拟机安装WindowsServer操作系统。服务器故障&分析:管理员因误操作...
- 「服务器数据恢复」Raid5阵列两块硬盘亮黄灯掉线的数据恢复案例
-
服务器数据恢复环境:HPStorageWorks某型号存储;虚拟化平台为vmwareexsi;10块磁盘组成raid5(有1块热备盘)。服务器故障:raid5阵列中两块硬盘指示灯变黄掉线,无法读取...
- 服务器数据恢复—基于oracle数据库的SAP数据恢复案例
-
服务器存储数据恢复环境:某品牌服务器存储中有一组由6块SAS硬盘组建的RAID5阵列,其中有1块硬盘作为热备盘使用。上层划分若干lun,存放Oracle数据库数据。服务器存储故障&分析:该RAID5阵...
- 「服务器虚拟化数据恢复」Xen Server环境下数据库数据恢复案例
-
服务器虚拟化数据恢复环境:Dell某型号服务器;数块STAT硬盘通过raid卡组建的RAID10;XenServer服务器虚拟化系统;故障虚拟机操作系统:WindowsServer,部署Web服务...
- 服务器数据恢复—RAID故障导致oracle无法启动的数据恢复案例
-
服务器数据恢复环境:某品牌服务器中有一组由4块SAS磁盘做的RAID5磁盘阵列。该服务器操作系统为windowsserver,运行了一个单节点Oracle,数据存储为文件系统,无归档。该oracle...
- 服务器数据恢复—服务器磁盘阵列常见故障表现&解决方案
-
RAID(磁盘阵列)是一种将多块物理硬盘整合成一个虚拟存储的技术,raid模块相当于一个存储管理的中间层,上层接收并执行操作系统及文件系统的数据读写指令,下层管理数据在各个物理硬盘上的存储及读写。相对...
- 「服务器数据恢复」IBM某型号服务器RAID5磁盘阵列数据恢复案例
-
服务器数据恢复环境:IBM某型号服务器;5块SAS硬盘组成RAID5磁盘阵列;存储划分为1个LUN和3个分区:第一个分区存放windowsserver系统,第二个分区存放SQLServer数据库,...
- 服务器数据恢复—Zfs文件系统下误删除文件如何恢复数据?
-
服务器故障:一台zfs文件系统服务器,管理员误操作删除服务器上的数据。服务器数据恢复过程:1、将故障服务器所有磁盘编号后取出,硬件工程师检测所有硬盘后没有发现有磁盘存在硬件故障。以只读方式将全部磁盘做...
- 服务器数据恢复—Linux+raid5服务器数据恢复案例
-
服务器数据恢复环境:某品牌linux操作系统服务器,服务器中有4块SAS接口硬盘组建一组raid5阵列。服务器中存放的数据有数据库、办公文档、代码文件等。服务器故障&检测:服务器在运行过程中突然瘫痪,...
- 服务器数据恢复—Sql Server数据库数据恢复案例
-
服务器数据恢复环境:一台安装windowsserver操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。在windows服务器内装有SqlServer数据库。存储空间LU...
- 服务器数据恢复—阿里云ECS网站服务器数据恢复案例
-
云服务器数据恢复环境:阿里云ECS网站服务器,linux操作系统+mysql数据库。云服务器故障:在执行数据库版本更新测试时,在生产库误执行了本来应该在测试库执行的sql脚本,导致生产库部分表被tru...
你 发表评论:
欢迎- 一周热门
-
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
WindowsServer2022|配置NTP服务器的命令
-
Ubuntu系统Daphne + Nginx + supervisor部署Django项目
-
WIN11 安装配置 linux 子系统 Ubuntu 图形界面 桌面系统
-
解决Linux终端中“-bash: nano: command not found”问题
-
NBA 2K25虚拟内存不足/爆内存/内存占用100% 一文速解
-
Linux 中的文件描述符是什么?(linux 打开文件表 文件描述符)
-
K3s禁用Service Load Balancer,解决获取浏览器IP不正确问题
-
- 最近发表
-
- 服务器数据恢复—Raid5数据灾难不用愁,Raid5数据恢复原理了解下
- 服务器数据恢复—多次异常断电导致服务器raid不可用的数据恢复
- 服务器数据恢复-V7000存储更换磁盘数据同步失败的数据恢复案例
- 「服务器数据恢复」重装系统导致XFS文件系统分区丢失的数据恢复
- 服务器数据恢复-ESXi虚拟机被误删的数据恢复案例
- 「服务器数据恢复」Raid5阵列两块硬盘亮黄灯掉线的数据恢复案例
- 服务器数据恢复—基于oracle数据库的SAP数据恢复案例
- 「服务器虚拟化数据恢复」Xen Server环境下数据库数据恢复案例
- 服务器数据恢复—RAID故障导致oracle无法启动的数据恢复案例
- 服务器数据恢复—服务器磁盘阵列常见故障表现&解决方案
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)