(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型等,而当我们想创建一些较为复杂的东西时,单单用一个类型变量是没办法做到的,比如我们想创建一个…...
可穿戴设备电池选型与电源管理实战指南
1. 项目概述:为什么可穿戴设备的电池选型是个技术活 做可穿戴电子项目,无论是智能手环、发光服饰还是互动饰品,最让人头疼的往往不是代码和电路,而是最后那一步: 怎么给它供电 。你可能花了好几天调通了传感器和灯带…...
从手机SoC到汽车芯片:深入聊聊AMBA总线家族(AHB/APB/AXI)的选型与实战踩坑
从手机SoC到汽车芯片:AMBA总线家族的选型与实战经验 在移动计算和汽车电子两大领域,芯片架构师们每天都在面临类似的挑战:如何在有限的硅片面积和功耗预算内,实现最高的系统性能。AMBA总线作为连接处理器、内存和各种外设的"…...
这3个降AI提示词千万别用!让你的知网AI率反涨10个点过不了AIGC检测
这3个降AI提示词千万别用!让你的知网AI率反涨10个点过不了AIGC检测 室友的真实事故——降 AI 提示词用错知网 AI 率反涨 3 月 19 号晚上室友哭着发消息:「我上网搜了一个降 AI 万能提示词改完段落送知网测——AI 率从 67% 涨到 77% 了!这怎…...
基于TypeScript的MCP服务器开发指南:为AI助手构建安全工具调用能力
1. 项目概述:一个为TypeScript开发者打造的MCP服务器最近在折腾AI应用开发,特别是想给Claude、Cursor这类智能助手扩展更强大的工具调用能力时,不可避免地接触到了Model Context Protocol。如果你也在研究如何让AI助手安全、可控地访问文件系…...
基于RAG的Obsidian智能知识库:本地部署与优化实战
1. 项目概述:当知识管理遇上大语言模型 如果你和我一样,是 Obsidian 的深度用户,同时又对大语言模型(LLM)的智能涌现能力感到着迷,那么你肯定也想过一个问题:能不能让我的知识库“活”起来&…...
基础教程通过Taotoken CLI一键配置开发环境与API密钥
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 基础教程:通过Taotoken CLI一键配置开发环境与API密钥 对于开发团队而言,让新成员快速、统一地接入大模型服…...
淘宝反爬升级应对:从Selenium到Playwright的迁移实践
前言 随着淘宝反爬体系持续迭代升级,传统 Selenium 爬虫面临指纹特征暴露、浏览器特征极易识别、检测门槛持续降低三大痛点。大量基于 Selenium 的淘宝爬虫出现账号限流、页面 403 拦截、滑块强校验、直接封禁 IP 等问题。 在电商爬虫、价格监控、商品采集、店铺数…...
初创团队如何利用Taotoken低成本启动AI功能并灵活扩展
🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 初创团队如何利用Taotoken低成本启动AI功能并灵活扩展 对于初创团队而言,在产品中引入人工智能能力是提升竞争力的关键…...
年度名场面!黄仁勋逛胡同被投喂豆汁,眉头紧锁。网友:弥补了没有喝过 XX 的遗憾
5 月 15 日,「黄仁勋 南锣鼓巷」话题突然在多平台引爆热议。谁能想到,手握 5 万亿美刀市值的科技大佬,私下里竟是胡同干饭人。昨天在大会堂还是西装革履,今天老黄换上他的经典皮肤套装,带几名随行人员低调逛南锣鼓巷和…...
保姆级拆解:用代码和图示彻底搞懂YOLOv7的Backbone与Head(附ELAN模块详解)
保姆级拆解:用代码和图示彻底搞懂YOLOv7的Backbone与Head(附ELAN模块详解) 在计算机视觉领域,目标检测一直是热门研究方向。YOLO系列作为其中的佼佼者,以其高效和准确著称。YOLOv7作为该系列的最新成员,在速…...
