(k8s)Kubernetes 从0到1容器编排之旅

一、引言

在当今数字化的浪潮中,Kubernetes 如同一艘强大的航船,引领着容器化应用的部署与管理。它以其卓越的灵活性、可扩展性和可靠性,成为众多企业和开发者的首选。然而,要真正发挥 Kubernetes 的强大威力,仅仅掌握基本操作是远远不够的。本文将带你深入探索 Kubernetes 使用过程中的奇技妙法,为你开启一段优雅的容器编排之旅。

二、高级资源管理之精妙艺术

  1. 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. 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. 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. 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. 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. 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. 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. 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. 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. 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. 1. 监控与日志收集:点亮洞察之灯

    • • 建立完善的监控和日志收集系统,就像点亮了一盏洞察之灯。Kubernetes 提供了一些工具,如 Prometheus 和 Grafana 用于监控集群的性能指标,以及 Elasticsearch、Fluentd 和 Kibana(EFK)用于收集和分析容器的日志。

    • • 操作示例:安装 Prometheus 和 Grafana,配置 Prometheus 来采集 Kubernetes 集群的指标,并在 Grafana 中创建仪表盘来展示监控数据。

    • • 安装 EFK 栈,配置 Fluentd 来收集容器的日志,并将日志发送到 Elasticsearch,然后使用 Kibana 来查询和分析日志。

  2. 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. 1. 蓝绿部署与金丝雀发布:谋划部署之策

    • • 蓝绿部署和金丝雀发布就像是一位战略家在谋划部署之策。通过同时维护两个版本的应用,或者逐步将流量引入到新版本的应用中,可以在不影响用户的情况下进行应用的升级和测试。

    • • 操作示例:对于蓝绿部署,首先部署新版本的应用到一个独立的命名空间或环境中,进行充分的测试。然后,使用 Ingress 或 Service Mesh 的路由规则,将流量从旧版本切换到新版本。

    • • 对于金丝雀发布,使用 HPA 或手动调整 Pod 的数量,逐步将一小部分流量引入到新版本的应用中,观察其性能和稳定性。如果新版本表现良好,可以逐步增加流量,直到全部切换到新版本。

  2. 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. 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. 1. RBAC(Role-Based Access Control):筑牢安全之墙

    • • RBAC 就像是一位坚固的卫士,为 Kubernetes 资源筑牢安全之墙。通过定义角色和角色绑定,可以实现精细的权限管理,确保只有授权的用户和服务能够访问特定的资源。

    • • 操作示例:创建一个 Role 对象来定义一组权限,然后创建一个 RoleBinding 对象将这个角色绑定到一个用户或服务账户。

apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:name: my-rolenamespace: my-n

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/879533.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

加密与安全_优雅存储用户密码的最佳实践

文章目录 Pre概述最佳实践避免使用MD5、SHA1等快速哈希算法加盐哈希 &#xff08;不推荐&#xff09;使用BCrypt、Argon2等慢哈希算法 (推荐)BCrypt Code1. 自动生成和嵌入盐2. 哈希结果的格式3. 代价因子 BCrypt特点 防止暴力破解1. 登录失败锁定2. 双因素认证&#xff08;2FA…

Golang | Leetcode Golang题解之第409题最长回文串

题目&#xff1a; 题解&#xff1a; func longestPalindrome(s string) int {mp : map[byte]int{}for i : 0; i < len(s); i {mp[s[i]]}res : 0for _, v : range mp {if v&1 1 {res v - 1} else {res v}}if res<len(s) {res}return res }

Python酷库之旅-第三方库Pandas(117)

目录 一、用法精讲 516、pandas.DataFrame.add_suffix方法 516-1、语法 516-2、参数 516-3、功能 516-4、返回值 516-5、说明 516-6、用法 516-6-1、数据准备 516-6-2、代码示例 516-6-3、结果输出 517、pandas.DataFrame.align方法 517-1、语法 517-2、参数 51…

Go语言基本语法

Go语言&#xff08;通常称为Golang&#xff09;是由Google开发的一种静态类型、编译型语言&#xff0c;它旨在简化系统编程、网络编程和并发编程的复杂性。 Go语言以其简洁、高效和易于理解的语法而受到开发者的喜爱。 Go语言的一些基本语法元素&#xff1a; 1. 包&#xff…

protobuf中c、c++、python使用

文章目录 protobuf实例&#xff1a;例题1&#xff1a;[CISCN 2023 初赛]StrangeTalkBot分析&#xff1a;思路&#xff1a;利用&#xff1a; 例题2&#xff1a;[CISCN 2024]protoverflow分析&#xff1a; protobuf Protocol Buffers&#xff0c;是Google公司开发的一种数据描述语…

数学学习记录

9月14日 1.映射&#xff1a; 2.函数: 9月15日 3.反函数&#xff1a; 4.收敛数列的性质 5.反三角函数&#xff1a; 9月16日 6.函数的极限&#xff1a; 7.无穷小和无穷大 极限运算法则&#xff1a;

远程Linux网络连接( Linux 网络操作系统 04)

接下来我们准备开始进入Linux操作系统的第二个模块的学习&#xff0c;不过在学习之前我们需要对如下进行简单的配置&#xff0c;通过外接辅助软件MobaXterm来进行虚拟操作系统的访问。接下来的课程我们会一直在MobaXterm中进行命令和相关知识的学习。 一、准备阶段 1.1 软件 …

学习笔记JVM篇(三)

一、垃圾回收机制 垃圾回收&#xff08;Garbage Collection&#xff09;机制&#xff0c;是自动回收无用对象从而释放内存的一种机制。Java之所以相对简单&#xff0c;很大程度是归功于垃圾回收机制。&#xff08;例如C语言申请内存后要手动的释放&#xff09; 优点&#xff…

数据清洗-缺失值填充-K-NN算法(K-Nearest Neighbors, K-NN算法)

目录 一、安装所需的python包二、采用K-NN算法进行缺失值填充2.1可直接运行代码2.2以某个缺失值数据进行实战2.2.1代码运行过程截屏&#xff1a;2.2.2填充后的数据截屏&#xff1a; 三、K 近邻算法 (K-Nearest Neighbors, KNN) 介绍3.1 K 近邻算法定义3.2 K 近邻算法的基本思想…

福建科立讯通信 指挥调度管理平台 SQL注入漏洞

北峰通信-福建科立讯通信 指挥调度管理平台 SQL注入漏洞 厂商域名和信息收集 域名&#xff1a; 工具sqlmap python sqlmap.py -u "http://ip:端口/api/client/down_file.php?uuid1" --batch 数据包 GET /api/client/down_file.php?uuid1%27%20AND%20(SELECT%20…

替换 Oracle ,江河信息用 TDengine 解决高基数查询写入问题

在数字经济快速发展的背景下&#xff0c;智慧水利作为重要的基础设施之一&#xff0c;正逐步成为提升水资源管理效率、优化生态环境的重要力量。江西省水投江河信息技术有限公司&#xff08;以下简称“江河信息”&#xff09;作为高新技术国有企业&#xff0c;坚定致力于打造数…

Leetcode 每日一题:Longest Increasing Path in a Matrix

写在前面&#xff1a; 今天我们继续看一道 图论和遍历 相关的题目。这道题目的背景是在一个矩阵当中找寻最长的递增数列长度。思路上非常好想&#xff0c;绝对和 DFS 相关&#xff0c;但是题目的优化要求非常高&#xff0c;对于语言和内存特性的考察特别丰富&#xff0c;如果是…

15. Springboot集成Redis

目录 1、前言 2、为什么选择Spring Boot集成Redis&#xff1f; 3、快速上手 3.1、引入依赖 3.2、 配置连接信息 3.3、自定义配置类 4、RedisTemplate的使用 4.1、String类型操作 4.2、 Hash类型操作 4.3、List类型操作 4.4、Set类型操作 4.5、SortedSet类型操作 4…

第十一章 【后端】商品分类管理微服务(11.2)——Lombok

11.2 Lombok 官网:https://projectlombok.org/ 较新版本的 idea 已默认安装 lombok 插件 Lombok 工具提供一系列的注解,使用这些注解可以不用定义 getter、setter、equals、constructor 等,可以消除 java 代码的臃肿,编译时它会在字节码文件中自动生成这些通用的方法,简…

ElK 8 收集 Nginx 日志

1. 说明 elk 版本&#xff1a;8.15.0 2. 启个 nginx 有 nginx 可以直接使用。我这里是在之前环境下 docker-compose.yml 中启动了个 nginx&#xff1a; nginx:restart: alwaysimage: nginx:1.26.1ports:- "80:80"- "443:443"volumes:#- ./nginx/html:/…

【题解】—— LeetCode一周小结37

&#x1f31f;欢迎来到 我的博客 —— 探索技术的无限可能&#xff01; &#x1f31f;博客的简介&#xff08;文章目录&#xff09; 【题解】—— 每日一道题目栏 上接&#xff1a;【题解】—— LeetCode一周小结36 9.合并零之间的节点 题目链接&#xff1a;2181. 合并零之间…

Unity实战案例全解析:PVZ 植物放置分析

前篇&#xff1a;Unity实战案例全解析&#xff1a;PVZ 植物卡片状态分析-CSDN博客 植物应该如何从卡牌状态转为实物&#xff1f; 其实就只需要考虑两个步骤加一个后续处理&#xff1a; 1.点击卡牌后就实例化 需要一个植物状态枚举&#xff0c;因为卡牌分为拿在手上和种植下…

CS61C 2020计算机组成原理Lecture01-数字表示,溢出

1. 原码 原码就是符号化的数值&#xff0c;其编码规则简单直观&#xff1a;正数符号位用0表示&#xff0c;负数符号位用1表示&#xff0c;数值位保持不变。 x0.1101&#xff0c;则[x]原0.1101&#xff1b;x1101&#xff0c;则[x]原01101x -0.1111&#xff0c;则[x]原1.1111&…

Oracle从入门到放弃

Oracle从入门到放弃 左连接和右连接Where子查询单行子查询多行子查询 from子句的子查询select子句的子查询oracle分页序列序列的应用 索引PL/SQL变量声明与赋值select into 赋值变量属性类型 异常循环游标存储函数存储过程不带传出参数的存储过程带传出参数的存储过程 左连接和…

opencv之Canny边缘检测

文章目录 前言1.应用高斯滤波去除图像噪声2.计算梯度3.非极大值抑制4.应用双阈值确定边缘5.Canny函数及使用 前言 Canny边缘检测是一种流行的边缘检测算法&#xff0c;用于检测图像中的边缘。它通过一系列步骤将图像中的像素边缘突出显示出来&#xff0c;主要分为以下几个步骤…