一、安装环境
data:image/s3,"s3://crabby-images/6e50b/6e50bc9d8a0a1ca28aaad7d23049836e6b5ec60f" alt=""
二、前期准备
1.设置免密登录
[root@k8s-master ~]# ssh-keygen
[root@k8s-master ~]# ssh-copy-id root@192.168.2.77
[root@k8s-master ~]# ssh-copy-id root@192.168.2.88
2.yum源配置
data:image/s3,"s3://crabby-images/703c0/703c0b27e3c4bd0083d2321e527d73b8c759a495" alt=""
data:image/s3,"s3://crabby-images/4955c/4955c814b3eb0fff0a783015692d99c30f21cb1e" alt=""
data:image/s3,"s3://crabby-images/9a164/9a16429203be0895fe2353fe64c514159a9562b6" alt=""
3.清空创建缓存
data:image/s3,"s3://crabby-images/d000a/d000ad7fc071e41f013fc036e3e79952c0530d86" alt=""
4.主机映射(三台主机都要设置)
data:image/s3,"s3://crabby-images/489dc/489dc0c27d438a8afc34848033ed0bd33676998a" alt=""
5.安装常用工具
data:image/s3,"s3://crabby-images/ee0ba/ee0ba7afdafb99810e7a5eef2aace527463c2e77" alt=""
6.关闭firewalld NetworkManager selinux swap虚拟分区
data:image/s3,"s3://crabby-images/b9071/b9071358db8830875ce46a183d458ff1891f7523" alt=""
data:image/s3,"s3://crabby-images/a486e/a486e5db477dab71d64b714a0842461f5004719e" alt=""
7.同步时间
data:image/s3,"s3://crabby-images/91adb/91adb3eaee75d1160b63fef13a6b1c4a97dae885" alt=""
8.配置limit
data:image/s3,"s3://crabby-images/c930d/c930d635e19d89692e362072a7e52b86e864f245" alt=""
9.下载yaml文件从gitee上下载
配置pod的yaml文件和docker-compose.uaml文件相似
data:image/s3,"s3://crabby-images/db2cd/db2cd22920eeb1eb8e1b4c1143b7819bb5e36030" alt=""
三、配置内核模块
1.ipvs的配置(三个节点)
data:image/s3,"s3://crabby-images/55fa7/55fa7ae6838f33ee6d05f941cb9ce94278653445" alt=""
data:image/s3,"s3://crabby-images/13cd9/13cd956e8de521e4fbee5f6cc801cfb6b2bb6f07" alt=""
data:image/s3,"s3://crabby-images/1a33f/1a33fd2ed66f172694dc416126e99da1f9ad062e" alt=""
2.k8s的内核加载(三个)
data:image/s3,"s3://crabby-images/316e7/316e77871a3475442fc6db7282f4d4f09fc81884" alt=""
data:image/s3,"s3://crabby-images/3aa19/3aa1900b60a0bc7886c5eb4fc38d0b56055d4818" alt=""
data:image/s3,"s3://crabby-images/6e2b6/6e2b62547b58b4c72ef678ade4c593f316745a02" alt=""
四、基本组件安装
1.三个节点安装docker-ce docker-ce-cli containerd.io(三个)
data:image/s3,"s3://crabby-images/4bf1a/4bf1a5b2b9b6852cc79e781e1c87783602b7eba1" alt=""
2.配置containerd所需模块(三个)
data:image/s3,"s3://crabby-images/b8b5b/b8b5b752f8ff8dcad82adf23c474af03c8385ed4" alt=""
3.配置containerd所需内核(三个)
data:image/s3,"s3://crabby-images/bcb68/bcb68d4022afa3c2e3ce0cb922880e7d9b5d661d" alt=""
data:image/s3,"s3://crabby-images/4da66/4da66fdcf72b5be92d7ac6766be0a54db09f5ac8" alt=""
4.containerd配置文件(三个)
data:image/s3,"s3://crabby-images/dce90/dce90d1e950f6b11e903e47ee0e43f805b0935f9" alt=""
5.配置 crictl 客户端连接的运⾏位置 (三个)
data:image/s3,"s3://crabby-images/804f5/804f5b3fe5db88f443e33781f77828810aec5c30" alt=""
6.安装kubernetes组件(三个节点)
data:image/s3,"s3://crabby-images/d463d/d463d168a4c9652cfa228ae78f2e06ec12f1d647" alt=""
data:image/s3,"s3://crabby-images/ccc78/ccc78bc4539098a95bcdd2c5f2508d6710b4ab47" alt=""
五、kubernetes集群初始化
1.kubeadm配置文件
data:image/s3,"s3://crabby-images/c790f/c790fe1dc030e342910975df50ea84c2e4d06820" alt=""
data:image/s3,"s3://crabby-images/e5a2f/e5a2fb999e848dd5ffff7f77b1e3bf2c125b3d64" alt=""
2.下载组件镜像
3.集群初始化
data:image/s3,"s3://crabby-images/40743/407436be4e33b29ade50e87d4d5d99e6ae9b66ea" alt=""
4.node加入集群
data:image/s3,"s3://crabby-images/ef072/ef072376945d1d52cb09f350fbb05b237e529c9c" alt=""
data:image/s3,"s3://crabby-images/9783e/9783e39406302735edc3f08420b70e1599e10e57" alt=""
5.查看组件容器状态
data:image/s3,"s3://crabby-images/b0bc4/b0bc4af3fa915e5024916e20a67ae42d8a6fd530" alt=""
data:image/s3,"s3://crabby-images/e576d/e576da974ea01f3f45ba3ebad69daa0a1eb0088f" alt=""
status:
data:image/s3,"s3://crabby-images/c135b/c135b96ddfe198a08056df27488f7a854bad4e5f" alt=""
六、部署calico
1.calico的部署
data:image/s3,"s3://crabby-images/356e1/356e18702b90f4be5f3d9351053d276288ba6f63" alt=""
data:image/s3,"s3://crabby-images/2ad94/2ad94f0702a716c3acf439f8700738ba24660639" alt=""
2 . 补 充 :
(1)如果出现这种错误
data:image/s3,"s3://crabby-images/a8b5a/a8b5abfbecb0a3987f4d366dee2e9e0bbe7617ea" alt=""
data:image/s3,"s3://crabby-images/52766/5276682e35a9a435d3804411832c8bc56a152b33" alt=""
(2)解决办法:
data:image/s3,"s3://crabby-images/45bf6/45bf651f34a0d40a63f13850624c464d05d765dd" alt=""
data:image/s3,"s3://crabby-images/ccd55/ccd55ed787c4214f9b6b491b397956bee95e88f4" alt=""
3.测试
(1)创建节点
data:image/s3,"s3://crabby-images/ab2a6/ab2a675d74339a91ff22bb10378a1beed9547e95" alt=""
(2)删除节点
data:image/s3,"s3://crabby-images/c5a0a/c5a0a0e2e63191a98ad9c77eeb59ad613ba1db36" alt=""
七、Metrics部署
1.复制证书到所有节点
data:image/s3,"s3://crabby-images/ab65b/ab65b0585473549e644ab408bcdeb8e2d2e59725" alt=""
2.安装metrics server
[root@k8s-master ~]# ls components.yaml
components.yaml
[root@k8s-master ~]# mkdir pods
[root@k8s-master ~]# mv components.yaml pods/
[root@k8s-master ~]# cd pods/
[root@k8s-master pods]# ls
components.yaml
[root@k8s-master pods]# cat components.yaml | wc -l
202
添加metric server的pod资源
[root@k8s-master pods]# kubectl create -f components.yaml
在kube-system命名空间下查看metrics server的pod运⾏状态
[root@k8s-master pods]# kubectl get po -A|grep metrics
kube-system metrics-server-79776b6d54-dmwk6 1/1 Running 0 2m26s
3.查看节点监控资源
data:image/s3,"s3://crabby-images/0913e/0913eedfb1c713c55eedc1ed7e59f1908766fb67" alt=""
4.dashboard部署
[root@k8s-master pods]# cd ~/k8s-ha-install/
[root@k8s-master k8s-ha-install]# ls
bootstrap CoreDNS dashboard metrics-server README.md
calico csi-hostpath kubeadm-metrics-server pki snapshotter
[root@k8s-master k8s-ha-install]# cd dashboard/
[root@k8s-master dashboard]# ls
dashboard-user.yaml dashboard.yaml
简历dashboard的pod资源
[root@k8s-master dashboard]# kubectl create -f .
[root@k8s-master dashboard]# kubectl get po -A|grep dashboard
kubernetes-dashboard dashboard-metrics-scraper-7b554c884f-7489m 1/1 Running 0 58s
kubernetes-dashboard kubernetes-dashboard-54b699784c-fsjrw 0/1 ContainerCreating 0 58s
[root@k8s-master dashboard]# kubectl edit svc kubernetes-dashboard -n kubernetes-dashboard
32 type: NodePort
Edit cancelled, no changes made.
edit:进⼊kubernetes的⽂本编辑器
svc:指定某个服务项,这⾥指定的是kubernetes-dashboard
-n:指定命名空间,kubernetes-dashboard
命令执⾏后相当于进⼊vim⽂本编辑器,不要⽤⿏标滚轮,会输出乱码的!可以使⽤"/"搜索,输⼊"/type"找到⽬
标,如果已经为NodePort忽略此步骤
查看访问端口号
获取kubernetes-dashboard状态信息,包含端⼝,服务IP等
[root@k8s-master dashboard]# kubectl get svc kubernetes-dashboard -n kubernetes-dashboard
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes-dashboard NodePort 10.96.242.161 <none> 443:30754/TCP 4m7s
5.浏览器访问:192.168.2.66:30754
找到端⼝号后,通过 master 的 IP+端⼝即可访问 dashboard(端⼝为终端查询到的端⼝,要⽤ https 协议访问)
data:image/s3,"s3://crabby-images/8be0c/8be0c99b75db0c6dedc2f02dd8cdb5b5b1c34c3b" alt=""
6.获得登录的token
data:image/s3,"s3://crabby-images/de33f/de33f9501304c7ad3ef2f7ba253d6e5080f9fbbd" alt=""
7.将获得的token粘贴到浏览器中
1)在"输⼊ token "内输⼊终端⽣成的 token
data:image/s3,"s3://crabby-images/27230/2723012cc3beacf34a1f2174b254bc697eb74181" alt=""
2)就可以进行登录了
data:image/s3,"s3://crabby-images/f3f4c/f3f4c709329bc918001a5a126a0e0f9a15b34e4b" alt=""
8.使用nginx镜像创建一个节点
data:image/s3,"s3://crabby-images/ff943/ff9438c51dfe8d37917a04c731562e24e1b0741e" alt=""
9.访问页面上就会显示出来
data:image/s3,"s3://crabby-images/5ab04/5ab04190ef7bd24572167e92280c1acfae13b111" alt=""
10.在访问页面中也可以查看日志
data:image/s3,"s3://crabby-images/9f861/9f861973eed1d4dc46254e8b1f6e0f111276c2d9" alt=""
11.在访问页面中创建节点
data:image/s3,"s3://crabby-images/6eced/6ecedac155445117afa6cfeaab0f6ba481a90844" alt=""
data:image/s3,"s3://crabby-images/2f697/2f697db8f1cff5bc084c3ab8ad360045b5497755" alt=""
12.在Linux中可以查到
data:image/s3,"s3://crabby-images/57dbe/57dbe185ca1af1979415df43ba621b1c9f34b7f0" alt=""
八、kube-proxy
1.改为ipvs模式
data:image/s3,"s3://crabby-images/90107/90107fe4957178684eb85f09614e0778427fca10" alt=""
2.更新kube-proxy的pod
data:image/s3,"s3://crabby-images/0bb90/0bb90de8930a4c90eb942de17e0e5e26d5a9fa78" alt=""
3.访问测试
data:image/s3,"s3://crabby-images/96647/966475353a966c43315ce0d88524b67ff72d8d53" alt=""
4.查看服务的网段
data:image/s3,"s3://crabby-images/52950/52950016cf704ca0836a3a1a8cec277bf1e25496" alt=""
5.验证是否可正常创建参数
data:image/s3,"s3://crabby-images/9e5bb/9e5bbfc34792ecfc26abef5ff331d43eb351b322" alt=""
6.进到创建的节点中
data:image/s3,"s3://crabby-images/d069c/d069cd632b8312939711ee39cab9f12a080d1da2" alt=""
data:image/s3,"s3://crabby-images/392b3/392b3a4fad63ee48d325370e84c9d0cf43ee2022" alt=""
7.访问dns的443端口和53端口
data:image/s3,"s3://crabby-images/8964b/8964b405e2c37b3c1917840745d19473ebfbbb3c" alt=""
九、kubernetes自动补齐
1.安装自动补齐
data:image/s3,"s3://crabby-images/25487/25487183c57636603183a01c34cc57732d43bbb0" alt=""
2.kubernetes基础命令
data:image/s3,"s3://crabby-images/0ecef/0ecef8ac932c4e115e888678e1fbd30ab7527b5e" alt=""
3.编写yaml文件-创建节点
data:image/s3,"s3://crabby-images/b3597/b3597ff386fbccb78d3a6220175d9c232f6bd031" alt=""
data:image/s3,"s3://crabby-images/13c90/13c90fabad88e0f2b24afce1a47142b0ed127f5c" alt=""
4.编辑json文件
data:image/s3,"s3://crabby-images/2f405/2f405b86c5276643b8ecbcfff32cfcd17dd96b0c" alt=""