【Kubernetes】(一)k8s基础

目录

[一、Kubernetes 是什么?](#一、Kubernetes 是什么?)

[二、Kubernetes 不是什么?](#二、Kubernetes 不是什么?)

[三、从部署演进看 Kubernetes 的价值](#三、从部署演进看 Kubernetes 的价值)

[1. 传统部署时代](#1. 传统部署时代)

[2. 虚拟化部署时代](#2. 虚拟化部署时代)

[3. 容器部署时代](#3. 容器部署时代)

[四、为什么我们需要 Kubernetes?](#四、为什么我们需要 Kubernetes?)


一、Kubernetes 是什么?

Kubernetes 这个名字源于希腊语,意为 "舵手" 或 "飞行员",它由 Google 在 2014 年开源,是建立在 Google 十余年大规模生产负载经验之上的容器编排引擎。

简单来说,Kubernetes 是一个用于弹性运行分布式系统的框架。在生产环境中,我们需要管理成百上千个应用容器,并确保服务永不离线。如果某个容器崩溃,系统能自动启动另一个容器来替代它,这些操作如果由人工处理,无疑是低效且容易出错的。Kubernetes 的核心使命,就是让这一切自动化。

它提供的核心能力包括:

服务发现与负载均衡:使用 DNS 或 IP 暴露服务,并自动分配流量,使部署更稳定。

存储编排:自动挂载本地存储、云存储等多种存储系统。

自动部署与回滚:以受控速率更新或回滚容器,确保业务连续性。

自动装箱:根据 CPU 和内存需求,智能调度容器到最合适的节点。

自我修复:重启失败容器,替换无响应容器,在就绪前不对外提供服务。

密钥与配置管理:安全存储和管理密码、令牌等敏感信息,无需重建镜像。

批处理执行:管理批处理和 CI/CD 工作负载,替换失败的任务容器。

水平扩缩:通过简单命令或根据 CPU 使用率自动扩缩容。

IPv4/IPv6 双栈:为 Pod 和 Service 同时分配 IPv4 和 IPv6 地址。

可扩展性设计:在不修改上游代码的前提下,为集群添加自定义功能。


二、Kubernetes 不是什么?

理解 Kubernetes,更重要的是理解它不是什么,这能帮我们避免很多认知误区:

不是 PaaS:它不限制应用类型,不提供内置的中间件、数据库或存储服务,所有这些都可以在其上运行,但由用户选择。

不构建应用:它不负责源码编译和应用构建,CI/CD 流程由企业自主决定。

不规定解决方案:它不强制日志、监控或告警方案,只提供了集成示例和指导。

不是配置语言:它提供了一个声明式 API,可以被任何形式的规范所驱动。

不是自洽系统:它不提供全面的机器配置、维护或自愈能力,需要与其他工具配合。


三、从部署演进看 Kubernetes 的价值

要理解 Kubernetes 的价值,我们需要回顾一下应用部署的演进史:

1. 传统部署时代

在早期,应用直接运行在物理服务器上。这导致了资源隔离的难题:一个应用可能占用大部分资源,导致其他应用性能下降。为了解决这个问题,我们不得不将应用部署在不同的物理服务器上,这又造成了资源利用率低下和维护成本高昂的问题。

2. 虚拟化部署时代

虚拟化技术的出现,让我们可以在一台物理服务器上运行多个虚拟机(VM)。每个 VM 都是一个完整的计算机,拥有自己的操作系统,应用之间被隔离开来。这极大地提高了资源利用率和可扩展性,但 VM 依然是重量级的,启动和迁移都比较缓慢。

3. 容器部署时代

容器技术(如 Docker)则更进一步。它与 VM 类似,提供了文件系统、CPU、内存和进程空间的隔离,但它共享宿主机的操作系统内核,因此更加轻量级。

容器带来了诸多优势:

敏捷部署:镜像创建和部署速度远超 VM。

环境一致:在笔记本、数据中心和云端运行的应用完全一致。

可移植性强:可以跨云、跨操作系统发行版自由迁移。

微服务友好:应用被拆分为独立的微服务,便于弹性扩展和管理。


四、为什么我们需要 Kubernetes?

容器解决了 "如何打包和运行应用" 的问题,但当我们有成百上千个容器时,如何管理它们?如何确保它们高可用?如何让它们高效协作?

这正是 Kubernetes 要解决的问题。它不再是一个简单的 "编排工具",而是一个由独立且可组合的控制流构成的系统。它持续地将当前状态驱动到我们设定的期望状态,而不需要人工干预或集中式控制。

从传统部署到虚拟化,再到容器化,最后到 Kubernetes,我们追求的始终是更高效、更可靠、更灵活的应用交付方式。Kubernetes 正是这个时代的最佳实践,它让我们从繁琐的运维工作中解放出来,真正聚焦于应用本身。

相关推荐
艾文伯特15 小时前
k8s-1.35-centos7-安装文档
云原生·容器·kubernetes
AOwhisky15 小时前
Kubernetes(K8s)学习笔记(第十四期):集群存储与有状态应用(下篇):StatefulSet 有状态应用管理
redis·笔记·mysql·云原生·kubernetes·云计算·k8s
AOwhisky16 小时前
kubernetes(K8s)学习笔记:第八期与第九期核心知识点自测与详解
笔记·云原生·kubernetes·云计算·k8s·集群·网络策略
蜀道山老天师1 天前
K8s 数据存储全解析:从 EmptyDir 到 PV/PVC
云原生·容器·kubernetes
创世宇图1 天前
【Python工程化实战】Kubernetes 中 Python 应用的优雅启停与健康检查:零停机滚动更新实战
python·云原生·kubernetes·优雅停机
阿里云云原生3 天前
研发视角的新突破:当 AI Coding 工具集成全域运维诊断,排查线上故障只需 3 分钟
云原生
小猿姐4 天前
唯品会大规模数据库云原生实践:基于 KubeBlocks 管理数千实例的统一运维之路
运维·elasticsearch·云原生
阿里云云原生4 天前
AgentTeams 和 Claude Tag 都进入群聊模式,是新范式还是新叙事?
云原生·agent
阿里云云原生5 天前
Higress v2.2.3 发布:正式入驻 CNCF Sandbox,AI Gateway 与 Ingress 迁移能力双向加固
云原生
阿里云云原生6 天前
香港站【企业 AI Agent 工程化实战专场】来啦,邀您7月9日见!
云原生·agent