(k8s)Kubernetes 从0到1容器编排之旅
一、引言
在当今数字化的浪潮中,Kubernetes 如同一艘强大的航船,引领着容器化应用的部署与管理。它以其卓越的灵活性、可扩展性和可靠性,成为众多企业和开发者的首选。然而,要真正发挥 Kubernetes 的强大威力,仅仅掌握基本操作是远远不够的。本文将带你深入探索 Kubernetes 使用过程中的奇技妙法,为你开启一段优雅的容器编排之旅。
二、高级资源管理之精妙艺术
-
1. 资源配额与限制:雕琢资源之美
-
• Kubernetes 允许为命名空间精心设置资源配额,如同一位艺术家在画布上勾勒出资源的边界。通过巧妙地设置 CPU 和内存的 requests 和 limits,可以精准地控制容器的资源使用,确保不同团队或项目之间和谐共处,避免资源的过度消耗。
-
• 操作示例:使用以下命令为命名空间“my-namespace”设置资源配额,限制 CPU 和内存的使用总量。
-
apiVersion: v1
kind: ResourceQuota
metadata:name: my-resource-quotanamespace: my-namespace
spec:hard:requests.cpu: "2"requests.memory: "4Gi"limits.cpu: "4"limits.memory: "8Gi"
-
• 可以使用
kubectl apply -f
命令来应用这个资源配额配置。
-
1. 弹性伸缩:舞动资源之灵
-
• Horizontal Pod Autoscaler(HPA)就像是一位灵动的舞者,能够根据 CPU 使用率或其他指标自动调整 Pod 的数量。在流量的高峰与低谷之间,它轻盈地舞动,为应用提供恰到好处的资源支持。
-
• 操作示例:首先,为你的 Deployment 或 ReplicaSet 添加资源请求和限制,然后创建一个 HPA 对象来自动调整 Pod 的数量。
-
apiVersion: autoscaling/v2beta2
kind: HorizontalPodAutoscaler
metadata:name: my-hpanamespace: my-namespace
spec:scaleTargetRef:apiVersion: apps/v1kind: Deploymentname: my-deploymentminReplicas: 2maxReplicas: 10metrics:- type: Resourceresource:name: cputarget:type: UtilizationaverageUtilization: 70
-
• 使用
kubectl apply -f
命令应用 HPA 配置。
-
1. 资源亲和性与反亲和性:编织资源之网
-
• 资源亲和性和反亲和性规则如同编织一张精细的资源之网,让 Pod 在节点上的分布更加合理。可以根据应用的特点和需求,将具有特定需求的 Pod 部署在合适的节点上,提高系统的可靠性和性能。
-
• 操作示例:在 Deployment 的配置文件中添加亲和性和反亲和性规则。
-
apiVersion: apps/v1
kind: Deployment
metadata:name: my-deploymentnamespace: my-namespace
spec:template:spec:affinity:nodeAffinity:requiredDuringSchedulingIgnoredDuringExecution:nodeSelectorTerms:- matchExpressions:- key: disk-typeoperator: Invalues:- ssdpodAntiAffinity:requiredDuringSchedulingIgnoredDuringExecution:- labelSelector:matchExpressions:- key: appoperator: Invalues:- my-apptopologyKey: "kubernetes.io/hostname"
-
• 应用这个配置文件来实现资源的亲和性和反亲和性。
三、网络优化之优雅旋律
-
1. Ingress 与 Service Mesh:奏响网络之曲
-
• Ingress 作为集群的入口,宛如一位优雅的指挥家,将外部流量巧妙地路由到内部的服务。而 Service Mesh,如 Istio,则像是一支精湛的乐队,为网络流量带来更高级的管理和安全控制。两者结合,共同奏响一曲网络优化的优雅旋律。
-
• 操作示例:安装 Istio,并为你的应用创建一个 Gateway 和 VirtualService 对象来定义入口流量的路由规则。
-
apiVersion: networking.istio.io/v1alpha3
kind: Gateway
metadata:name: my-gatewaynamespace: my-namespace
spec:selector:istio: ingressgatewayservers:- port:number: 80name: httpprotocol: HTTPhosts:- "*"
---
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:name: my-virtual-servicenamespace: my-namespace
spec:gateways:- my-gatewayhosts:- "*"http:- route:- destination:host: my-serviceport:number: 80
-
• 使用
kubectl apply -f
命令应用这些配置。
-
1. NetworkPolicy:谱写安全之章
-
• NetworkPolicy 如同一位严谨的作曲家,为 Pod 之间的网络访问谱写安全之章。通过定义精细的网络访问规则,可以有效地控制哪些 Pod 可以相互通信,哪些 Pod 不能通信,提高系统的安全性。
-
• 操作示例:创建一个 NetworkPolicy 对象来限制 Pod 之间的网络访问。
-
apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:name: my-network-policynamespace: my-namespace
spec:podSelector:matchLabels:app: my-apppolicyTypes:- Ingress- Egressingress:- from:- podSelector:matchLabels:app: allowed-appports:- protocol: TCPport: 80egress:- to:- podSelector:matchLabels:app: allowed-destinationports:- protocol: TCPport: 443
-
• 应用这个 NetworkPolicy 配置来限制网络访问。
-
1. 跨集群通信:演绎协同之舞
-
• 在复杂的场景下,跨集群通信就像是一场精彩的协同之舞。Kubernetes 提供了 Federation 和 Service Mesh 的跨集群模式等解决方案,让不同的集群之间能够实现资源的统一管理和跨集群的服务发现。
-
• 操作示例:使用 Kubernetes Federation 来联合多个集群。首先,安装 Federation 控制器,然后创建一个 Federation 资源对象来定义跨集群的资源。
-
apiVersion: federation.k8s.io/v1beta1
kind: Cluster
metadata:name: cluster1
spec:serverAddressByClientCIDRs:- clientCIDR: "0.0.0.0/0"serverAddress: "https://cluster1-api-server-address"
---
apiVersion: federation.k8s.io/v1beta1
kind: FederatedDeployment
metadata:name: my-federated-deploymentnamespace: my-namespace
spec:template:metadata:labels:app: my-appspec:replicas: 3selector:matchLabels:app: my-apptemplate:metadata:labels:app: my-appspec:containers:- name: my-containerimage: my-imageplacement:clusters:- name: cluster1- name: cluster2
-
• 应用这个配置来实现跨集群的部署。
四、存储优化之细腻笔触
-
1. PersistentVolumeClaim(PVC)与 PersistentVolume(PV):描绘存储之画
-
• PVC 和 PV 就像是画家手中的画笔和画布,为应用提供持久化存储。通过合理设置存储类和访问模式,可以描绘出满足不同应用需求的存储画卷。
-
• 操作示例:创建一个 StorageClass 对象来定义存储类,然后创建一个 PV 和 PVC 对象来请求存储。
-
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:name: my-storage-class
provisioner: kubernetes.io/aws-ebs
parameters:type: gp2
reclaimPolicy: Retain
---
apiVersion: v1
kind: PersistentVolume
metadata:name: my-pv
spec:capacity:storage: 10GiaccessModes:- ReadWriteOncepersistentVolumeReclaimPolicy: RetainstorageClassName: my-storage-classawsElasticBlockStore:volumeID: <volume-id>fsType: ext4
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:name: my-pvcnamespace: my-namespace
spec:accessModes:- ReadWriteOnceresources:requests:storage: 5GistorageClassName: my-storage-class
-
• 应用这些配置来创建持久化存储。
-
1. StatefulSet:铸就存储之魂
-
• StatefulSet 如同一位雕塑家,为有状态应用铸就存储之魂。它可以为每个 Pod 分配一个稳定的存储和网络标识,使得有状态应用在升级和故障恢复时更加可靠。
-
• 操作示例:创建一个 StatefulSet 对象来部署有状态应用。
-
apiVersion: apps/v1
kind: StatefulSet
metadata:name: my-statefulsetnamespace: my-namespace
spec:serviceName: my-servicereplicas: 3selector:matchLabels:app: my-apptemplate:metadata:labels:app: my-appspec:containers:- name: my-containerimage: my-imagevolumeMounts:- name: my-persistent-storagemountPath: /datavolumeClaimTemplates:- metadata:name: my-persistent-storagespec:accessModes:- ReadWriteOnceresources:requests:storage: 5GistorageClassName: my-storage-class
-
• 应用这个配置来部署有状态应用。
-
1. 存储插件:挥洒存储之彩
-
• Kubernetes 支持多种存储插件,就像画家拥有丰富的颜料一样。根据存储需求选择合适的存储插件,可以挥洒出绚丽多彩的存储画卷。
-
• 操作示例:安装和配置所需的存储插件,如 Ceph、GlusterFS 等。以 Ceph 为例,首先安装 Ceph 集群,然后在 Kubernetes 中创建一个 Ceph RBD StorageClass。
-
apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:name: ceph-rbd
provisioner: kubernetes.io/rbd
parameters:monitors: <ceph-monitor-addresses>pool: <rbd-pool-name>imageFormat: "2"imageFeatures: "layering"
reclaimPolicy: Retain
-
• 然后可以使用这个 StorageClass 来创建 PVC 和 PV,为应用提供 Ceph 存储。
五、故障排查与调试之睿智洞察
-
1. kubectl 命令行工具:开启洞察之窗
-
• kubectl 就像是一把神奇的钥匙,开启了故障排查与调试的洞察之窗。通过丰富的命令,可以查看资源的详细信息、容器的日志,甚至在容器内部执行命令进行故障排查。
-
• 操作示例:使用
kubectl describe
命令查看 Pod 的详细信息。
-
kubectl describe pod my-pod -n my-namespace
• 使用kubectl logs
命令查看容器的日志。
kubectl logs my-pod -n my-namespace
• 使用kubectl exec
命令在容器内部执行命令进行故障排查。
kubectl exec -it my-pod -n my-namespace -- bash
-
1. 监控与日志收集:点亮洞察之灯
-
• 建立完善的监控和日志收集系统,就像点亮了一盏洞察之灯。Kubernetes 提供了一些工具,如 Prometheus 和 Grafana 用于监控集群的性能指标,以及 Elasticsearch、Fluentd 和 Kibana(EFK)用于收集和分析容器的日志。
-
• 操作示例:安装 Prometheus 和 Grafana,配置 Prometheus 来采集 Kubernetes 集群的指标,并在 Grafana 中创建仪表盘来展示监控数据。
-
• 安装 EFK 栈,配置 Fluentd 来收集容器的日志,并将日志发送到 Elasticsearch,然后使用 Kibana 来查询和分析日志。
-
-
2. 调试工具:施展洞察之术
-
• Kubernetes 还提供了一些调试工具,如
kubectl debug
和ephemeral-container
。这些工具就像是魔法师的法术,能够在运行中的 Pod 中启动一个临时容器,用于进行故障排查和调试。 -
• 操作示例:使用
kubectl debug
命令在 Pod 中启动一个调试容器。
-
kubectl debug my-pod -n my-namespace --image=<debug-image>
• 使用ephemeral-container
功能,在不重启 Pod 的情况下,为其添加一个临时容器。
apiVersion: v1
kind: Pod
metadata:name: my-podnamespace: my-namespace
spec:containers:- name: my-containerimage: my-imageephemeralContainers:- name: debug-containerimage: <debug-image>command: ["/bin/bash"]stdin: truetty: true
-
• 使用
kubectl replace
命令应用这个配置,添加临时容器进行调试。
六、高级部署策略之精妙布局
-
1. 蓝绿部署与金丝雀发布:谋划部署之策
-
• 蓝绿部署和金丝雀发布就像是一位战略家在谋划部署之策。通过同时维护两个版本的应用,或者逐步将流量引入到新版本的应用中,可以在不影响用户的情况下进行应用的升级和测试。
-
• 操作示例:对于蓝绿部署,首先部署新版本的应用到一个独立的命名空间或环境中,进行充分的测试。然后,使用 Ingress 或 Service Mesh 的路由规则,将流量从旧版本切换到新版本。
-
• 对于金丝雀发布,使用 HPA 或手动调整 Pod 的数量,逐步将一小部分流量引入到新版本的应用中,观察其性能和稳定性。如果新版本表现良好,可以逐步增加流量,直到全部切换到新版本。
-
-
2. A/B 测试:探索用户之需
-
• A/B 测试就像是一位市场研究员在探索用户之需。通过在 Kubernetes 中使用流量路由规则,可以将一部分流量引导到 A 版本的应用,另一部分流量引导到 B 版本的应用,然后通过监控和分析用户行为来确定哪个版本的应用更优。
-
• 操作示例:使用 Service Mesh 的流量路由规则,创建一个 VirtualService 对象来定义 A/B 测试的路由规则。
-
apiVersion: networking.istio.io/v1alpha3
kind: VirtualService
metadata:name: my-virtual-servicenamespace: my-namespace
spec:hosts:- my-servicehttp:- route:- destination:host: my-service-v1subset: v1weight: 50- destination:host: my-service-v2subset: v2weight: 50
-
• 这里将 50%的流量引导到 A 版本(my-service-v1),50%的流量引导到 B 版本(my-service-v2)。然后通过监控和分析用户行为来确定哪个版本更优。
-
1. 滚动更新:稳步推进之法
-
• 滚动更新是 Kubernetes 中默认的部署策略,就像一位稳健的行者在稳步推进。它可以逐步更新 Pod,以确保应用的可用性。在滚动更新过程中,Kubernetes 会逐个替换旧版本的 Pod,同时确保新版本的 Pod 正常运行后才继续替换下一个 Pod。
-
• 操作示例:在 Deployment 的配置文件中,可以调整滚动更新的参数,如最大不可用 Pod 数量和最大 surge 数量。
-
apiVersion: apps/v1
kind: Deployment
metadata:name: my-deploymentnamespace: my-namespace
spec:replicas: 10strategy:type: RollingUpdaterollingUpdate:maxSurge: 2maxUnavailable: 1template:metadata:labels:app: my-appspec:containers:- name: my-containerimage: my-image
-
• 这里设置最大 surge 数量为 2,表示在更新过程中可以同时创建最多 2 个新的 Pod。最大不可用 Pod 数量为 1,表示在更新过程中最多可以有 1 个 Pod 不可用。
七、安全加固之坚固防线
-
1. RBAC(Role-Based Access Control):筑牢安全之墙
-
• RBAC 就像是一位坚固的卫士,为 Kubernetes 资源筑牢安全之墙。通过定义角色和角色绑定,可以实现精细的权限管理,确保只有授权的用户和服务能够访问特定的资源。
-
• 操作示例:创建一个 Role 对象来定义一组权限,然后创建一个 RoleBinding 对象将这个角色绑定到一个用户或服务账户。
-
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:name: my-rolenamespace: my-n
相关文章:

(k8s)Kubernetes 从0到1容器编排之旅
一、引言 在当今数字化的浪潮中,Kubernetes 如同一艘强大的航船,引领着容器化应用的部署与管理。它以其卓越的灵活性、可扩展性和可靠性,成为众多企业和开发者的首选。然而,要真正发挥 Kubernetes 的强大威力,仅仅掌握…...

Rust Web开发框架对比:Warp与Actix-web
文章目录 Rust Web开发框架对比:Warp与Actix-web引言框架概述Warp框架简介Actix-web框架简介 设计理念Warp的设计理念Actix-web的设计理念 性能比较可扩展性和生态插件和中间件支持社区和文档 使用示例使用Warp构建简单的HTTP服务使用Actix-web构建简单的HTTP服务 学…...

F12抓包12:Performance(性能)前端性能分析
课程大纲 使用场景: ① 前端界面加载性能测试。 ② 导出性能报告给前端开发。 复习:后端(接口)性能分析 ① 所有请求耗时时间轴:“网络”(Network) - 概览。 ② 单个请求耗时:“网络”(Network…...

数据结构(Day13)
一、学习内容 内存空间划分 1、一个进程启动后,计算机会给该进程分配4G的虚拟内存 2、其中0G-3G是用户空间【程序员写代码操作部分】【应用层】 3、3G-4G是内核空间【与底层驱动有关】 4、所有进程共享3G-4G的内核空间,每个进程独立拥有0G-3G的用户空间 …...

链表的快速排序(C/C++实现)
一、前言 大家在做需要排名的项目的时候,需要把各种数据从高到低排序。如果用的快速排序的话,处理数组是十分简单的。因为数组的存储空间的连续的,可以通过下标就可以简单的实现。但如果是链表的话,内存地址是随机分配的…...

css总结(记录一下...)
文字 语法说明word-wrapword-wrap:normal| break-word normal:使用浏览器默认的换行 break-word:允许在单词内换行 text-overflow clip:修剪文本 ellipsis:显示省略符号来代表被修剪的文本 text-shadow可向文本应用的阴影。能够规定水平阴影、垂直阴影、模糊距离,以…...

SpringBoot 处理 @KafkaListener 消息
消息监听容器 1、KafkaMessageListenerContainer 由spring提供用于监听以及拉取消息,并将这些消息按指定格式转换后交给由KafkaListener注解的方法处理,相当于一个消费者; 看看其整体代码结构: 可以发现其入口方法为doStart(),…...

Spring Boot-API版本控制问题
在现代软件开发中,API(应用程序接口)版本控制是一项至关重要的技术。随着应用的不断迭代,API 的改动不可避免,如何在引入新版本的同时保证向后兼容,避免对现有用户的影响,是每个开发者需要考虑的…...

Git 提取和拉取的区别在哪
1. 提取(Fetch) 操作说明:Fetch 操作会从远程仓库下载最新的提交、分支信息等,但不会将这些更改合并到你当前的分支中。它只是将远程仓库的更新信息存储在本地,并不会自动修改你当前的工作区。 使用场景: …...

【数据结构与算法 | 每日一题 | 力扣篇】力扣2390, 2848
1. 力扣2390:从字符串中删除星号 1.1 题目: 给你一个包含若干星号 * 的字符串 s 。 在一步操作中,你可以: 选中 s 中的一个星号。移除星号 左侧 最近的那个 非星号 字符,并移除该星号自身。 返回移除 所有 星号之…...

破解信息架构实施的密码:常见挑战与最佳解决方案全指南
信息架构的成功实施是企业数字化转型的关键步骤,但在实际操作中,企业往往会遇到各种复杂的挑战。这些挑战包括 技术整合的难度、数据管理的复杂性、合规性要求的变化 以及 资源限制 等。《信息架构:商业智能&分析与元数据管理参考模型》为…...

CodeChef Starters 151 (Div.2) A~D
codechef是真敢给分,上把刚注册,这把就div2了,再加上一周没打过还是有点不适应的,好在最后还是能够顺利上分 今天的封面是P3R的设置菜单 我抠出来做我自己的游戏主页了( A - Convert string 题意 在01串里面可以翻转…...

Redis学习——数据不一致怎么办?更新缓存失败了又怎么办?
文章目录 引言正文读写缓存的数据一致性只读缓存的数据一致性删除和修改数据不一致问题操作执行失败导致数据不一致解决办法 多线程访问导致数据不一致问题总结 总结参考信息 引言 最近面试快手的时候被问到了缓存不一致怎么解决?一开始还是很懵的,因为…...

跨境电商代购新纪元:一键解锁全球好物,系统流程全揭秘
添加图片注释,不超过 140 字(可选) 在全球化日益加深的今天,跨境电商代购成为了连接消费者与世界各地优质商品的桥梁。本文将在CSDN平台上,深入剖析跨境电商代购系统的功能流程,带您一窥其背后的技术奥秘与…...

Mac 上终端使用 MySql 记录
文章目录 下载安装终端进入 MySql常用操作查看数据库选择一个数据库查看当前选择的数据库Navcat 打开提示报错参考文章 下载安装 先下载社区版的 MySql 安装的过程需要设置 root 的密码,这个是要进入数据库所设定的,所以要记住 终端进入 MySql 首先输…...

461. 汉明距离
一:题目: 两个整数之间的 汉明距离 指的是这两个数字对应二进制位不同的位置的数目。 给你两个整数 x 和 y,计算并返回它们之间的汉明距离。 示例 1: 输入:x 1, y 4 输出:2 解释: 1 (0 0…...

开发指南061-nexus权限管理
平台后台服务的核心是组件,管理组件的软件有: Apache的Archiva、JFrog的Artifactory、Sonatype的Nexus。 本平台选择nexus。nexus的权限模型是用户-角色-权限体系:通过组合权限定义角色,通过给用户赋角色来赋权限。有关nexus的权…...

Qt 弹出菜单右键菜单 QMenu 设置不同颜色的子项
概述 在Qt中,可以使用样式表(StyleSheet)来自定义 QMenu 的外观,包括其子项(如菜单项QAction)的颜色。但是,这通常可以设置 QMenu 的整体样式,而不能单独设置某个子项的颜色。不过&…...

Git换行符自动转换参数core.autocrlf的用法
core.autocrlf 是 Git 中用于控制换行符自动转换的配置选项。它有以下几个可能的值: 1. true 作用:在 checkin 时将 CRLF 转换为 LF,在 checkout 时将 LF 转换为 CRLF。适用场景:适用于 Windows 用户,希望在本地文件…...

C语言的结构体类型
在我们使用C语言进行编写代码时,常常会使用已经给定的类型来创建变量,比如int型,char型,double型等,而当我们想创建一些较为复杂的东西时,单单用一个类型变量是没办法做到的,比如我们想创建一个…...

illustrator 收集字体插件VBscript
这是早些年从俄罗斯网站上看到的一个收集字体插件,语言是用VBscript写的,能用,但个别字体不能收集完成,现在Adobe也在illustrator中加入了收集字体打包功能,所以这个也很少用啦。 使用方法: 下好插件,或把下面的代码存入到本地侯后缀名改为.vbs,然后把.ai文件往.vbs文…...

【LLM多模态】文生视频评测基准VBench
note VBench的16个维度自动化评估指标代码实践(待完成)16个维度的prompt举例人类偏好标注:计算VBench评估结果与人类偏好之间的相关性、用于DPO微调 文章目录 note一、相关背景二、VBench评测基准概述:论文如何解决这个问题&…...

通过覆写 url_for 将 flask 应用部署到子目录下
0. 缘起 最近用 flask 写了一个 web 应用,需要部署到服务器上。而服务器主域名已经被使用了,只能给主域名加个子目录进行部署,比如主域名 example.org ,我需要在 example.org/flask 下部署。这时 flask 应用里的内部连接们就出现…...

攻防世界---->埃尔隆德32
做题笔记。 下载 查壳。 32ida 打开。 发现就一个判断。 跟进看看。 // 首次a20 int __cdecl sub_8048414(_BYTE *a1, int a2) {int result; // eaxswitch ( a2 ){case 0:if ( *a1 105 )goto LABEL_19;result 0;break;case 1:if ( *a1 101 ) // e…...

redis短信登录模型
基于Session实现登录 ,...

【React】React18.2.0核心源码解读
前言 本文使用 React18.2.0 的源码,如果想回退到某一版本执行git checkout tags/v18.2.0即可。如果打开源码发现js文件报ts类型错误请看本人另一篇文章:VsCode查看React源码全是类型报错如何解决。 阅读源码的过程: 下载源码 观察 package…...

深度学习-目标检测(四)-Faster R-CNN
目录 一.模型框架 二:步骤详细 1.conv layers 2.RPN 3.anchors 4.cls layer分类 5.reg layer回归 6.Proprosal 7.Rol pooling 8.Classification 三.训练 1.训练RPN网络 2.全连接层部分训练: 都看到这里了,点个赞把!&a…...

MATLAB中的无线通信系统设计有哪些最佳实践
在无线通信系统设计领域,MATLAB提供了一套强大的工具箱,使得系统设计、仿真、测试和分析变得更加高效和精确。本文将探讨MATLAB在无线通信系统设计中的最佳实践,包括信号处理、调制与解调、信道建模、误码率分析以及无线通信标准的实现。 1.…...

Java的发展史与前景
🌈个人主页:Yui_ 🌈Linux专栏:Linux 🌈C语言笔记专栏:C语言笔记 🌈数据结构专栏:数据结构 🌈C专栏:C 文章目录 0. Java语言的发展史1.概述1.1 什么是Java1.2 …...

2024年上海小学生古诗文大会倒计时30多天:做几道今年的官方模拟题
2024年上海市小学生古诗文大会自由报名活动的初赛日期于10月19日开始,距离今天只有34天了。 小学生古诗文大会考什么?怎么考呢?今天好真题就带着大家来做一做官方发布的2024年小学生古诗文大会的模拟题,根据往年的经验࿰…...