diff --git "a/java\344\273\216\345\205\245\351\227\250\345\210\260\346\224\276\345\274\203/javaSE\345\237\272\347\241\200/2\343\200\201\345\237\272\347\241\200\345\255\246\344\271\240.md" "b/java\344\273\216\345\205\245\351\227\250\345\210\260\346\224\276\345\274\203/javaSE\345\237\272\347\241\200/2\343\200\201\345\237\272\347\241\200\345\255\246\344\271\240.md" index 431b9878a1e455d7dc05ad4255130a39b055a080..4357c1db8284fa49813cf1c32c5a73d95efa8933 100644 --- "a/java\344\273\216\345\205\245\351\227\250\345\210\260\346\224\276\345\274\203/javaSE\345\237\272\347\241\200/2\343\200\201\345\237\272\347\241\200\345\255\246\344\271\240.md" +++ "b/java\344\273\216\345\205\245\351\227\250\345\210\260\346\224\276\345\274\203/javaSE\345\237\272\347\241\200/2\343\200\201\345\237\272\347\241\200\345\255\246\344\271\240.md" @@ -691,3 +691,11 @@ char: - `const` (Java 10 引入,但未激活) - `goto` (未在Java中使用) +## 总结:标识符和关键字的区别 + +可以结合现实生活中的道德和法律去理解,标识符是生活中的道德,可以违背,但是...哈哈,违背了,你就是个没有道德的人呐 + +关键字可以理解成现实生活中的法律,如果违背了,可能就会受到一些强制性的手段啦... + +# 运算符 + diff --git "a/k8s\346\234\215\345\212\241/0-README.md" "b/k8s\346\234\215\345\212\241/0-README.md" new file mode 100644 index 0000000000000000000000000000000000000000..b44799e9184100e20c9444948134e663cb451ab0 --- /dev/null +++ "b/k8s\346\234\215\345\212\241/0-README.md" @@ -0,0 +1,6 @@ +# 学习前需掌握的前置知识 + +学习k8s需要你掌握Linux基础知识、docker及网络知识,这样会让你学习起来很轻松,如果没有掌握的话,你可以学习本仓库中相对应内容。 + +学习k8s你可以尽量了解nginx、tomcat等web服务器及其它工作中常用的服务,这样你可以使用k8s并部署,使你学习起来更加得心应手。 + diff --git "a/k8s\346\234\215\345\212\241/1-k8s\346\234\215\345\212\241\346\246\202\350\277\260.md" "b/k8s\346\234\215\345\212\241/1-k8s\346\234\215\345\212\241\346\246\202\350\277\260.md" new file mode 100644 index 0000000000000000000000000000000000000000..99b821a5e29208dc26c46608d971804f3199f65d --- /dev/null +++ "b/k8s\346\234\215\345\212\241/1-k8s\346\234\215\345\212\241\346\246\202\350\277\260.md" @@ -0,0 +1,217 @@ +# 来源 + +中文官网:https://kubernetes.io/zh + +中文社区:https://www.kubernetes.org.cn/ + +# 应用部署方式演变介绍 + +**应用部署方式演变** + +在部署应用程序的方式上,主要经历了三个时代: + +- **传统部署** + +互联网早期,会直接将应用程序部署在物理机上 + +优点:简单,不需要其它技术的参与缺点:不能为应用程序定义资源使用边界,很难合理地分配计算资源,而且程序之间容易产生影响 + +- **虚拟化部署** + +可以在一台物理机上运行多个虚拟机,每个虚拟机都是独立的一个环境 + +优点:程序环境不会相互产生影响,提供了一定程度的安全性缺点:增加了操作系统,浪费了部分资源 + +- **容器化部署** + +与虚拟化类似,但是共享了操作系统 + +优点:可以保证每个容器拥有自己的文件系统、CPU、内存、进程空间等运行应用程序所需要的资源都被容器包装,并和底层基础架构解耦容器化的应用程序可以跨云服务商、跨Linux操作系统发行版进行部署 + +​ ![0]() + +容器化部署方式给带来很多的便利,但是也会出现一些问题,比如说: + +- 一个容器故障停机了,怎么样让另外一个容器立刻启动去替补停机的容器 +- 当并发访问量变大的时候,怎么样做到横向扩展容器数量 + +这些容器管理的问题统称为**容器编排**问题,为了解决这些容器编排问题,就产生了一些容器编排的软件: + +- Swarm:Docker自己的容器编排工具 +- Mesos:Apache的一个资源统一管控的工具,需要和Marathon结合使用 +- Kubernetes:Google开源的的容器编排工具 + +![image-20240914103153091](./images/image-20240914103153091.png) + +# 概述 + +![image-20240914103203275](./images/image-20240914103203275.png) + +kubernetes,简称K8s,是用8 代替8 个字符“ubernete”而成的缩写。是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes 的目标是让部署容器化的应用简单并且高效(powerful),Kubernetes 提供了应用部署,规划,更新,维护的一种机制。 + +传统的应用部署方式是通过插件或脚本来安装应用。这样做的缺点是应用的运行、配置、管理、所有生存周期将与当前操作系统绑定,这样做并不利于应用的升级更新/回滚等操作,当然也可以通过创建虚拟机的方式来实现某些功能,但是虚拟机非常重,并不利于可移植性。 + +新的方式是通过部署容器方式实现,每个容器之间互相隔离,每个容器有自己的文件系统,容器之间进程不会相互影响,能区分计算资源。相对于虚拟机,容器能快速部署,由于容器与底层设施、机器文件系统解耦的。 + +Kubernetes 是一个轻便的和可扩展的开源平台,用于管理容器化应用和服务。通过Kubernetes 能够进行应用的自动化部署和扩缩容。在Kubernetes 中,会将组成应用的容器组合成一个逻辑单元以更易管理和发现。 + +Kubernetes 积累了作为Google 生产环境运行工作负载15 年的经验,并吸收了来自于社区的最佳想法和实践。 + +# K8S功能 + +### 自动装箱 + +基于容器对应用运行环境的资源配置要求自动部署应用容器 + +### 自我修复(自愈能力) + +当容器失败时,会对容器进行重启,当所部署的Node节点有问题时,会对容器进行重新部署和重新调度,当容器未通过监控检查时,会关闭此容器直到容器正常运行时,才会对外提供服务,如果某个服务器上的应用不响应了,Kubernetes会自动在其它的地方创建一个 + +### 水平扩展 + +通过简单的命令、用户UI 界面或基于CPU 等资源使用情况,对应用容器进行规模扩大或规模剪裁 + +> 当我们有大量的请求来临时,我们可以增加副本数量,从而达到水平扩展的效果 + +### 服务发现 + +用户不需使用额外的服务发现机制,就能够基于Kubernetes 自身能力实现服务发现和负载均衡 + +> 对外提供统一的入口,让它来做节点的调度和负载均衡, 相当于微服务里面的网关? + +### 滚动更新 + +可以根据应用的变化,对应用容器运行的应用,进行一次性或批量式更新 + +> 添加应用的时候,不是加进去就马上可以进行使用,而是需要判断这个添加进去的应用是否能够正常使用 + +### 版本回退 + +可以根据应用部署情况,对应用容器运行的应用,进行历史版本即时回退 + +> 类似于Git中的回滚 + +### 密钥和配置管理 + +在不需要重新构建镜像的情况下,可以部署和更新密钥和应用配置,类似热部署。 + +### 存储编排 + +自动实现存储系统挂载及应用,特别对有状态应用实现数据持久化非常重要 + +存储系统可以来自于本地目录、网络存储(NFS、Gluster、Ceph 等)、公共云存储服务 + +### 批处理 + +提供一次性任务,定时任务;满足批量数据处理和分析的场景 + +# k8s架构 + +一个kubernetes集群主要是由**控制节点(master)**、**工作节点(node)**构成,每个节点上都会安装不同的组件。 + +**master:集群的控制平面,负责集群的决策 ( 管理 )** + +- **APIServer**:资源操作的唯一入口,接收用户输入的命令,提供认证、授权、API注册和发现等机制**(资源操作的唯一入口)** +- **etcd**:**负责存储集群中各种资源对象的信息**(存储数据)** +- **Scheduler**: 负责集群资源调度,按照预定的调度策略将Pod调度到相应的node节点上**(负责pod调度)** +- **controller manager**:**负责维护集群的状态**,比如程序部署安排、故障检测、自动扩展、滚动更新等 + +**node/slave/worker**:**集群的数据平面,负责为容器提供运行环境 ( 干活 )** + +- **Kubelet**:管理Pod的生命周期上报节点状态,包括Pod和Node节点; +- **kube-proxy**:负责Pod的访问路由及负载均衡; + +![image-20240914102731846](./images/image-20240914102731846.png) + +# K8S常用术语 + +## OCI: + +OCI(Open Container Initiative)是指**开放容器标准**,它是一个轻量级、开放的治理结构,致力于围绕容器格式和运行时创建开放的行业标准 + +通过支持OCI规范,Kubernetes可以与多种容器运行时兼容,这使得K8s在容器编排和管理方面更加灵活和强大 + +## CRI: + +CRI(Container Runtime Interface)是Kubernetes定义的一组与容器运行时进行交互的接口。 + +CRI是Kubernetes用来与容器运行时进行交互的标准接口。它定义了一套RPC(远程过程调用)API,这些API被用来管理容器的生命周期。 + +目前实现了CRI spec的Runtime有**Docker Engine、containerd、CRI-O、Mirantis Container Runtime(Docker企业版)**等。 + +已经弃用的有**docker-shim** + +## CNI: + +CNI(Container Network Interface)是一个规范和框架,它允许Kubernetes通过插件化的方式集成各种网络解决方案,以实现集群内部容器之间的网络通信。 + +支持的网络模式:Overlay Network,Underlay Network,flannel,calico,cannel,cilium + +### 常用的CNI网络插件: + +1. Flannel:Flannel是一个开源的容器网络组件,用于为Kubernetes集群提供跨主机的容器网络。它支持多种后端网络,如UDP、VXLAN和Host-gw等。 +2. Calico是一个开源的容器网络解决方案,它使用BGP路由协议来构建容器之间的网络连接。Calico提供了高性能、可扩展和安全的容器网络。 + +# k8s的重大事件 + +2020年k8s宣布弃用docker-shim,2022年k8s的1.24版本正式弃用docker-shim,这个时候如果容器使用docker的话,需要单独部署docker-shim,docker-shim是属于CRI接口。所以后面的章节是采用K8s-1.23.17版本 + +# K8S核心概念 + +### Pod + +- Pod是K8s中最小的单元 +- 一组容器的集合 +- 共享网络【一个Pod中的所有容器共享同一网络】 +- 生命周期是短暂的(服务器重启后,就找不到了) + +### Volume + +- 声明在Pod容器中可访问的文件目录 +- 可以被挂载到Pod中一个或多个容器指定路径下 +- 支持多种后端存储抽象【本地存储、分布式存储、云存储】 + +### Controller + +- 确保预期的pod副本数量【ReplicaSet】 +- 无状态应用部署【Deployment】 + - 无状态就是指,不需要依赖于网络或者ip +- 有状态应用部署【StatefulSet】 + - 有状态需要特定的条件 +- 确保所有的node运行同一个pod 【DaemonSet】 +- 一次性任务和定时任务【Job和CronJob】 + +### Deployment + +- 定义一组Pod副本数目,版本等 +- 通过控制器【Controller】维持Pod数目【自动回复失败的Pod】 +- 通过控制器以指定的策略控制版本【滚动升级、回滚等】 + +![image-20240914103713522](./images/image-20240914103713522.png) + +### Service + +- 定义一组pod的访问规则 +- Pod的负载均衡,提供一个或多个Pod的稳定访问地址 +- 支持多种方式【ClusterIP、NodePort、LoadBalancer】 + +可以用来组合pod,同时对外提供服务 + +### Label + +label:标签,用于对象资源查询,筛选 + +### Namespace + +命名空间,逻辑隔离 + +- 一个集群内部的逻辑隔离机制【鉴权、资源】 +- 每个资源都属于一个namespace +- 同一个namespace所有资源不能重复 +- 不同namespace可以资源名重复 + +### API + +我们通过Kubernetes的API来操作整个集群 + +同时我们可以通过 kubectl 、ui、curl 最终发送 http + json/yaml 方式的请求给API Server,然后控制整个K8S集群,K8S中所有的资源对象都可以采用 yaml 或 json 格式的文件定义或描述 \ No newline at end of file diff --git "a/k8s\346\234\215\345\212\241/2-K8S\345\256\211\350\243\205\351\203\250\347\275\262.md" "b/k8s\346\234\215\345\212\241/2-K8S\345\256\211\350\243\205\351\203\250\347\275\262.md" new file mode 100644 index 0000000000000000000000000000000000000000..c8f894118a022f4aff66853f2aab8dc50dc82675 --- /dev/null +++ "b/k8s\346\234\215\345\212\241/2-K8S\345\256\211\350\243\205\351\203\250\347\275\262.md" @@ -0,0 +1,605 @@ +# k8s集群安装的方式 + +## 官方推荐的两种方式 + +- #### 二进制安装 + +需要运维人员手动部署各个组件,包括但不限于:证书,启动脚本,配置文件等。就算是老手部署集群,所有环境准备就绪的情况下,也得40min+。 + +从GitHub下载发行版的二进制包,手动部署每个组件,组成kubernetes集群。 + +- #### kubeadm一键安装 + +基于容器部署k8s集群,大部分组件都是基于容器部署的,因此部署速度较快,新手部署仅需1~2min搞定。 + +kubeadm是一个K8S部署工具,提供kubeadm init和kubeadm join,用于快速部署kubernetes集群。 + +## 其它方式安装 + +- **yum:** + +已废弃,目前支持的最新版本为2017年发行的1.5.2版本。 + +- **minikube:** + +适合开发环境,能够快速在Windows或者Linux构建K8S集群。 + +参考链接: + +https://minikube.sigs.k8s.io/docs/ + +- **rancher:** + +基于K8S改进发行了轻量级K8S,让K3S孕育而生。 + +参考链接: + +https://www.rancher.com/ + +- **KubeSphere:** + +青云科技基于开源KubeSphere快速部署K8S集群。 + +参考链接: + +https://kubesphere.com.cn + +- **kuboard:** + +也是对k8s进行二次开发的产品,新增了很多独有的功能。 + +参考链接: + +https://kuboard.cn/ + +- **kubeasz:** + +使用ansible部署,扩容,缩容kubernetes集群,安装步骤官方文档已经非常详细了。 + +参考链接: + +https://github.com/easzlab/kubeasz/ + +- **第三方云厂商:** + +比如aws(EKS),阿里云(ACK),腾讯云(TKE),华为云(CCE),京东云等云厂商均有K8S的相关SAAS产品。 + +- **更多的第三方部署工具:** + +参考链接: + + https://landscape.cncf.io/ + +# 基于kubeadm安装单节点K8S + +本章中基于kubeadm安装单节点K8S进行学习,后续会更新其它方式安装的方式 + +## 环境准备: + +ubuntu 22.04 + +| 主机名 | IP地址 | 配置 | 描述 | +| -------- | --------- | ---- | ------------------------------------- | +| master30 | 10.0.0.30 | 2c4g | 安装docker、kubelet、kubectl、kubeadm | +| worker31 | 10.0.0.31 | 2c4g | 安装docker、 | +| worker32 | 10.0.0.32 | 2c4g | 安装docker、 | + +## 步骤一:前提准备(所有节点操作) + +参考连接 + +https://kubernetes.io/zh/docs/setup/production-environment/tools/kubeadm/install-kubeadm/ + +#### **步骤一-1:关闭swap分区** + +```shell +#关闭swap分区 +root@master:~# swapoff -a && sysctl -w vm.swappiness=0 +vm.swappiness = 0 +root@master:~# sed -ri '/^[^#]*swap/s@^@#@' /etc/fstab + +#检查swap分区,为0B即可 +root@master:~# free -h + total used free shared buff/cache available +Mem: 3.8Gi 337Mi 2.8Gi 1.0Mi 698Mi 3.2Gi +Swap: 0B 0B 0B +root@master:~# +``` + +#### **步骤二-2:确保各个节点MAC地址或product_uuid唯一** + +```shell +root@master:~# cat /sys/class/dmi/id/product_uuid +5bef4d56-fbf2-045e-a104-dad2e4c6d809 +root@master:~# +#温馨提示: +# 一般来讲,硬件设备会拥有唯一的地址,但是有些虚拟机的地址可能会重复。 +# Kubernetes使用这些值来唯一确定集群中的节点。 如果这些值在每个节点上不唯一,可能会导致安装失败。 +``` + +#### **步骤二-3:检查各节点之间网络是否互通** + +```shell +#检查30 +[root@master ~]# ping 10.0.0.30 -c 1 +PING 10.0.0.30 (10.0.0.30) 56(84) bytes of data. +64 bytes from 10.0.0.30: icmp_seq=1 ttl=64 time=0.032 ms + +--- 10.0.0.30 ping statistics --- +1 packets transmitted, 1 received, 0% packet loss, time 0ms +rtt min/avg/max/mdev = 0.032/0.032/0.032/0.000 ms + +#检查31 +[root@master ~]# ping 10.0.0.31 -c 1 +PING 10.0.0.31 (10.0.0.31) 56(84) bytes of data. +64 bytes from 10.0.0.31: icmp_seq=1 ttl=64 time=0.589 ms + +--- 10.0.0.31 ping statistics --- +1 packets transmitted, 1 received, 0% packet loss, time 0ms +rtt min/avg/max/mdev = 0.589/0.589/0.589/0.000 ms + +#检查32 +[root@master ~]# ping 10.0.0.32 -c 1 +PING 10.0.0.32 (10.0.0.32) 56(84) bytes of data. +64 bytes from 10.0.0.32: icmp_seq=1 ttl=64 time=0.353 ms + +--- 10.0.0.32 ping statistics --- +1 packets transmitted, 1 received, 0% packet loss, time 0ms +rtt min/avg/max/mdev = 0.353/0.353/0.353/0.000 ms + +``` + +#### **步骤二-4:允许iptable检查桥接流量** + +```shell +[root@master ~]# cat < /dev/null +``` + +最后安装 + +``` +apt-get -y update +apt-get -y install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin +``` + +启动docker + +```shell +#启动docker +[root@master ~]# systemctl enable --now docker +Synchronizing state of docker.service with SysV service script with /lib/systemd/systemd-sysv-install. +Executing: /lib/systemd/systemd-sysv-install enable docker + +#检查版本 +[root@master ~]# docker --version +Docker version 27.2.1, build 9e34c9b + +#检查是否启动成功 +[root@master ~]# systemctl status docker +● docker.service - Docker Application Container Engine + Loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled) + Active: active (running) since Sat 2024-09-14 11:04:09 CST; 1min 25s ago +TriggeredBy: ● docker.socket + Docs: https://docs.docker.com + Main PID: 4262 (dockerd) + Tasks: 9 + Memory: 22.7M + CPU: 1.039s + CGroup: /system.slice/docker.service + └─4262 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock + +``` + +配置镜像加速可参考本仓库中docker相关的内容 + +#### **步骤二-8:所有节点修改docker的cgroup的管理进程为systemd** + +vim /etc/docker/daemon.json + +```shell +{ + #主要添加下面这行内容 + "exec-opts": ["native.cgroupdriver=systemd"] +} +``` + +检查 + +```shell +[root@worker31 ~]# docker info | grep "Cgroup Driver" + Cgroup Driver: systemd +``` + +## 步骤二:安装kubeadm,kubelet,kubectl(所有节点操作) + +安装说明: + +``` +kubeadm:用来初始化集群的指令。 +kubelet:在集群中的每个节点上用来启动Pod和容器等。 +kubectl:用来与集群通信的命令行工具。 + +注意事项: +kubeadm不能帮你安装或者管理kubelet或kubectl,所以你需要确保它们与通过kubeadm安装的控制平面(master)的版本相匹配。 如果不这样做,则存在发生版本偏差的风险,可能会导致一些预料之外的错误和问题。 + +然而,控制平面与kubelet间的相差一个次要版本不一致是支持的,但kubelet的版本不可以超过"API SERVER"的版本。 例如,1.7.0版本的kubelet可以完全兼容1.8.0版本的"API SERVER",反之则不可以。 +``` + +#### **K8S集群所有节点配置软件源和安装包** + +参考链接:https://kubernetes.io/zh/docs/tasks/tools/install-kubectl-linux/ + +```shell +#更新源,安装https证书相关之类的依赖 +apt-get update -y && apt-get install -y apt-transport-https +curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add - +#配置k8s相关的源 +cat </etc/apt/sources.list.d/kubernetes.list +deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main +EOF +#再次更新源 +apt-get update -y + + +#查看支持的版本 +apt-cache madison kubeadm + +#安装指定的版本 +apt-get install -y kubelet=1.23.17-00 kubeadm=1.23.17-00 kubectl=1.23.17-00 + +#设置开机自启动 +systemctl enable --now kubelet +``` + +## **步骤三:初始化master节点:** + +#### **步骤三-1:使用kubeadm命令初始化master节点** + +```shell +kubeadm init --kubernetes-version=v1.23.17 --image-repository=registry.aliyuncs.com/google_containers --pod-network-cidr=10.100.0.0/16 --service-cidr=10.200.0.0/16 --service-dns-domain=huangsir.com + + +命令解释: +--kubernetes-version: +指定K8S master组件的版本号。 +--image-repository:指定下载k8s master组件的镜像仓库地址。 +--pod-network-cidr:指定Pod的网段地址。 +--service-cidr:指定SVC的网段 +--service-dns-domain:指定service的域名。若不指定,默认为"cluster.local"。 + +这儿指定的两个网段,我们后面会补充是为什么 +``` + +初始化完成界面 + +![image-20240914112311899](./images/image-20240914112311899.png) + +**补充:使用kubeadm初始化集群时,可能会出现如下的输出信息:(了解)** + +``` + +[init] +使用初始化的K8S版本。 + +[preflight] +主要是做安装K8S集群的前置工作,比如下载镜像,这个时间取决于你的网速。 + +[certs] +生成证书文件,默认存储在"/etc/kubernetes/pki"目录哟。 + +[kubeconfig] +生成K8S集群的默认配置文件,默认存储在"/etc/kubernetes"目录哟。 + +[kubelet-start] + 启动kubelet, + 环境变量默认写入:"/var/lib/kubelet/kubeadm-flags.env" + 配置文件默认写入:"/var/lib/kubelet/config.yaml" + +[control-plane] +使用静态的目录,默认的资源清单存放在:"/etc/kubernetes/manifests"。 +此过程会创建静态Pod,包括"kube-apiserver","kube-controller-manager"和"kube-scheduler" + +[etcd] +创建etcd的静态Pod,默认的资源清单存放在:""/etc/kubernetes/manifests" + +[wait-control-plane] +等待kubelet从资源清单目录"/etc/kubernetes/manifests"启动静态Pod。 + +[apiclient] +等待所有的master组件正常运行。 + +[upload-config] +创建名为"kubeadm-config"的ConfigMap在"kube-system"名称空间中。 + +[kubelet] +创建名为"kubelet-config-1.22"的ConfigMap在"kube-system"名称空间中,其中包含集群中kubelet的配置 + +[upload-certs] +跳过此节点,详情请参考”--upload-certs" + +[mark-control-plane] +标记控制面板,包括打标签和污点,目的是为了标记master节点。 + +[bootstrap-token] +创建token口令,例如:"kbkgsa.fc97518diw8bdqid"。 +如下图所示,这个口令将来在加入集群节点时很有用,而且对于RBAC控制也很有用处哟。 + +[kubelet-finalize] +更新kubelet的证书文件信息 + +[addons] +添加附加组件,例如:"CoreDNS"和"kube-proxy” +``` + +#### **步骤三-2:拷贝授权文件,用于管理K8S集群** + +步骤三-1中初始化界面完成的地方 + +``` +mkdir -p $HOME/.kube +sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config +sudo chown $(id -u):$(id -g) $HOME/.kube/config +``` + +#### **步骤三-3:查看master组件状态** + +```shell +[root@master ~]# kubectl get cs +Warning: v1 ComponentStatus is deprecated in v1.19+ +NAME STATUS MESSAGE ERROR +scheduler Healthy ok +controller-manager Healthy ok +etcd-0 Healthy {"health":"true","reason":""} + +``` + +## **步骤四:将worker节点加入集群中(worker节点执行)** + +步骤三-1中初始化界面完成的地方 + +31节点和32节点都需要执行 + +``` +kubeadm join 10.0.0.30:6443 --token v7jfuf.s7d9zocx87snogaj \ + --discovery-token-ca-cert-hash sha256:c26164d8c47241892edd4663f7d0aeecacd254d07b789df4dfe9210dfd790262 +``` + +## **步骤五:master节点检查状态** + +```shell +[root@master ~]# kubectl get nodes +NAME STATUS ROLES AGE VERSION +master NotReady control-plane,master 9m16s v1.23.17 +worker31 NotReady 47s v1.23.17 +worker32 NotReady 40s v1.23.17 + + +#温馨提示: +#此时注意,所有的工作节点均处于"NotReady"状态,原因是没有安装CNI插件。 +``` + +## **步骤六:安装CNI插件(master节点执行)** + +```shell +[root@master ~]# cd ~ +#下载插件 +[root@master ~]# wget https://github.com/flannel-io/flannel/releases/latest/download/kube-flannel.yml +... +Connecting to objects.githubusercontent.com (objects.githubusercontent.com)|185.199.109.133|:443... connected. +HTTP request sent, awaiting response... 200 OK +Length: 4406 (4.3K) [application/octet-stream] +Saving to: ‘kube-flannel.yml’ + +kube-flannel.yml 100%[==========================================================================================================================================>] 4.30K --.-KB/s in 0s + +2024-09-14 11:32:13 (8.41 MB/s) - ‘kube-flannel.yml’ saved [4406/4406] + + +#修改CNI的网段为10.100.0.0 +[root@master ~]# sed -i 's#10.244.0.0#10.100.0.0#' kube-flannel.yml + + +#应用资源清单 +[root@master ~]# kubectl apply -f kube-flannel.yml +namespace/kube-flannel created +serviceaccount/flannel created +clusterrole.rbac.authorization.k8s.io/flannel created +clusterrolebinding.rbac.authorization.k8s.io/flannel created +configmap/kube-flannel-cfg created +daemonset.apps/kube-flannel-ds created +[root@master ~]# + +``` + +## **步骤七:查看pod是否创建成功** + +```shell +#查看flannel的pod,需要保证状态都为Running +[root@master ~]# kubectl get pods -o wide -n kube-flannel +NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES +kube-flannel-ds-9hz9c 1/1 Running 0 2m15s 10.0.0.31 worker31 +kube-flannel-ds-cx98g 1/1 Running 0 2m15s 10.0.0.30 master +kube-flannel-ds-pjwhv 1/1 Running 0 2m15s 10.0.0.32 worker32 + +#查看节点状态,需要保证状态为Ready +[root@master ~]# kubectl get nodes +NAME STATUS ROLES AGE VERSION +master Ready control-plane,master 14m v1.23.17 +worker31 Ready 5m51s v1.23.17 +worker32 Ready 5m44s v1.23.17 + +``` + +## 步骤八:**检查所有节点的网卡是否存在cni0和flannel.1** + +``` +ip a +#需要注意的是,一个节点中需要同时存在cni0和flannel.1两块网卡, +#且同一个节点的两块网卡需要在同一个网段。 +#如果网卡缺少cni0可以执行以下命令新建,需要注意网段 +#假设 master231的flannel.1是10.100.0.0网段。 +ip link add cni0 type bridge +ip link set dev cni0 up +ip addr add 10.100.2.1/24 dev cni0 +``` + +![image-20240914113752551](./images/image-20240914113752551.png) + +## 步骤九:配置kubectl命令自动补全(master节点执行) + +``` +apt -y install bash-completion +kubectl completion bash > ~/.kube/completion.bash.inc +echo "source '$HOME/.kube/completion.bash.inc'" >> $HOME/.bash_profile +source $HOME/.bash_profile +#配置完成后,换一个客户端连接试一下 +``` + +到此,一个简单的K8S集群安装就完成了,大家可以在自己虚拟机拍个快照防止出现意外哦 + +# 补充 + +## kubeadm、kubectl、kubelet各个组件的区别? + +- kubeadm:用来初始化集群的指令。 +- kubelet:在集群中的每个节点上用来启动Pod和容器等。 +- kubectl:用来与集群通信的命令行工具。 + +## K8S集群中的网段说明 + +这儿也就相当于步骤三执行的命令解释,K8S集群中是存在几个网段的,且每个网段都有自己的含义 + +- 宿主机网段 + +这个很好理解,该网段是给宿主机通信使用的,网段是10.0.0.0/24 + +- kubelet使用的网段 + +同一个worker节点中的每个pod也需要进行网络通信,所以每个pod需要分配一个IP地址,所以kubelet也需要给它一个网段 + +- service使用的网段 + +service用户管理pod,pod将请求发给service,由service负载路由到指定的pod,这里也需要一个网段 + +- CNI插件使用的网段 + +实现k8s集群内部的Pod跨主机访问,这个时候需要用CNI插件,这个时候需要给一个网段,子网掩码是16 \ No newline at end of file diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914102731846.png" "b/k8s\346\234\215\345\212\241/images/image-20240914102731846.png" new file mode 100644 index 0000000000000000000000000000000000000000..9248a48a5ba5934c985d138667d76529de719bc3 Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914102731846.png" differ diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914103153091.png" "b/k8s\346\234\215\345\212\241/images/image-20240914103153091.png" new file mode 100644 index 0000000000000000000000000000000000000000..5805cd078bc604d03207bbcbc6e711e4029f3b68 Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914103153091.png" differ diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914103203275.png" "b/k8s\346\234\215\345\212\241/images/image-20240914103203275.png" new file mode 100644 index 0000000000000000000000000000000000000000..247b4e3817abeee7f47e14d609d309ce724b29c7 Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914103203275.png" differ diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914103713522.png" "b/k8s\346\234\215\345\212\241/images/image-20240914103713522.png" new file mode 100644 index 0000000000000000000000000000000000000000..2655a8fc6f305eaf15a56cf28579a3b1de3a6b5c Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914103713522.png" differ diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914105547101.png" "b/k8s\346\234\215\345\212\241/images/image-20240914105547101.png" new file mode 100644 index 0000000000000000000000000000000000000000..fd366a43529dfebe9825b7c90a264cdc54802069 Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914105547101.png" differ diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914105559496.png" "b/k8s\346\234\215\345\212\241/images/image-20240914105559496.png" new file mode 100644 index 0000000000000000000000000000000000000000..a3e2f0c76df3acdaad497bb717eca10918e7caa8 Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914105559496.png" differ diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914112311899.png" "b/k8s\346\234\215\345\212\241/images/image-20240914112311899.png" new file mode 100644 index 0000000000000000000000000000000000000000..92038c5be7a069485ef9f8323059bbbcd93a2146 Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914112311899.png" differ diff --git "a/k8s\346\234\215\345\212\241/images/image-20240914113752551.png" "b/k8s\346\234\215\345\212\241/images/image-20240914113752551.png" new file mode 100644 index 0000000000000000000000000000000000000000..ecc72e07b86b109f4c39f5ff436f2b1b586ae68b Binary files /dev/null and "b/k8s\346\234\215\345\212\241/images/image-20240914113752551.png" differ