概念解读|K8s/容器云/裸金属/云原生...这些都有什么区别?

随着容器技术的日渐成熟,不少企业用户都对应用系统开展了容器化改造。而在容器基础架构层面,很多运维人员都更熟悉虚拟化环境,对“容器圈”的各种概念容易混淆:容器就是 Kubernetes 吗?容器云又是什么?容器怎么部署?裸金属和物理机有什么区别?容器虚拟化和虚拟化容器是一个东西吗?他们都算云原生吗?......为了帮助大家更好地理解容器基础架构层面的各种技术、选择适合自己的容器平台搭建方案,本文将针对 9 个容器热门概念进行解读和区分。

概括版

  • 云原生:专为充分利用和实现云计算特性而生(的技术/产品),围绕容器技术进行发展。

  • 容器:操作系统级虚拟化技术,“操作系统解耦”特性使得容器更具敏捷和可移植性。

  • Kubernetes:使用最为广泛的容器编排平台,可以大规模、自动化实现很多容器部署、管理和扩展等方面的操作。

  • 容器管理(软件/平台):简化 Kubernetes 的管理与运维操作,提升容器环境整体的管理效率。

  • 容器-虚拟化融合:目前一些企业用户可能同时在使用容器和虚拟化,“容器-虚拟化融合”技术能够实现两个环境互联互通、统一管理、统一调度,降低混合环境运维管理负担。主流技术有以下两种:

    • 容器虚拟化:在 Kubernetes 集群中创建、运行、管理虚拟机,以 KubeVirt 为代表。

    • 虚拟化容器:在虚拟化环境中部署、运行、管理容器和虚拟机,以 VMware Tanzu 和 SmartX SKS 为代表。

  • 容器云:以云化交付的形式提供的容器平台,一般包含 IaaS 层和 PaaS 层能力。

  • 裸金属:云化交付的物理服务器,在使用 Kubernetes 时,“裸金属“也可表示以物理机作为运行环境,与基于虚拟化环境运行 Kubernetes 进行对比。

概念全景图 

云原生(Cloud Native)

根据 Gartner 在《中国 IT 基础设施技术成熟度曲线,2024》中的定义,云原生即“专为充分利用和实现云计算特性而生”,这些特性既包括一部分云计算的原始定义,也包括以服务形式提供的功能。

因此,“云原生”是一个比较包容的概念,Gartner 也提到,目前用户对“云原生”有两种常见的理解:一种是“cloud-service-provider-native”,由云服务商原生的技术或产品;另一种是“container-native”,专为容器环境原生的技术或产品。其中,后面这种理解更符合“云原生”的初衷,也得到更多人的使用。在这种理解下,“云原生”技术/产品充分发挥容器、服务网格、基础设施自动化、CI/CD 等技术特性,加速并简化应用程序生命周期,从而提升 IT 生产力和敏捷性。

容器(Container)

参考 Kubernetes 指南的定义,容器是“一种便携式、轻量级的操作系统级虚拟化技术。它使用 namespace 隔离不同的软件运行环境,并通过镜像自包含软件的运行环境,从而使得容器可以很方便的在任何地方运行”。

容器 vs 虚拟化

与“软硬件解耦”的虚拟化技术不同,容器技术只对操作系统以上的层级进行虚拟化,容器间共享操作系统,在“硬件解耦”的同时实现了“操作系统解耦”,使得容器能够灵活地在多种运行环境间迁移(包括私有云、公有云、虚拟化、物理机等),获得超越虚拟机的敏捷性、数据一致性和可移植性,加快企业 IT 技术发展和业务效率。

云原生 vs 容器

容器是云原生技术发展的基石,但并不是所有支持容器/能在容器环境中使用的技术都是“云原生”技术。例如,用户可以采用本地磁盘/外置集中式存储为容器环境提供存储服务,但本地磁盘并不算是“云原生存储”。

Kubernetes(K8s)

Kubernetes 是一个开源容器编排平台,也是目前使用最为广泛的容器编排平台,由云原生计算基金会(CNCF)进行管理。以容器运行应用程序,传统的运维方式要求运维人员同时管理数个容器的创建、销毁、迁移、扩容等动作,非常耗费时间和精力。Kubernetes 能够帮助运维人员,将部署、管理和扩展容器化应用过程中涉及的许多手动操作以自动化的方式完成,提供的服务包括服务发现和负载均衡、存储编排、自动部署和回滚、资源计算、自我修复、密钥管理、水平扩展等,有效降低容器部署与运维难度,提高应用开发和交付速度。

Kubernetes 以集群的方式进行部署,每个 Kubernetes 集群由一个控制平面(Control Plane)和一个或多个工作节点(Node)组成,其中控制平面用来管理集群的整体状态,Node 是真正运行容器的主机,以 Pod 进行容器的管理。

Kubernetes vs Docker

Docker 是一个开源平台,进一步对容器进行了封装,以便各个进程相互独立运行。Docker 可以作为独立平台部署,也可被用作由 Kubernetes 编排的容器运行时(container runtime),将 Docker 在所有节点上对所有容器执行的操作进行自动化处理。Docker 和 Kubernetes 可以搭配使用,开发人员往往会使用 Docker 来建立和操作容器映像,使用 Kubernetes 进行大规模的容器编排。举例来说就是,容器是一个个集装箱,Docker 是装载集装箱的货船,Kubernetes 将货船组成同一个舰队,而更上层的容器管理服务(见下)就是码头的调度。

容器管理(Container Management)

虽然 Kubernetes 能够帮助用户轻松地进行容器编排,但其学习成本较高,原生 Kubernetes 也只支持命令行模式(Kubectl),对于一些习惯了虚拟化图形式操作界面的运维人员并不友好,带来了较大的管理难度。因此,一些厂商提供了容器管理软件/平台,简化 Kubernetes 的管理与运维操作,帮助用户高效进行容器管理。

根据 Gartner 在《中国 IT 基础设施技术成熟度曲线,2024》中的描述,容器管理平台的主要功能包括编排和调度、服务发现和注册、镜像注册表、路由和网络、服务目录、管理用户界面以及 API。借助这些能力,企业能够更加轻松地管理、扩展基于微服务的应用程序,加速实现应用云原生架构和基础设施现代化转型。不过,目前国内很多容器管理产品和云原生生态系统严重依赖开源技术,建议用户(尤其是对数据合规性要求严格的企业)仔细甄别产品能力和潜在安全风险。

Kubernetes vs 容器管理

容器管理软件/平台一般构建在 Kubernetes 之上,协助进行 Kubernetes 集群生命周期的自动化管理,如自动化完成 Kubernetes 集群创建、删除、更新、扩缩容等原本流程繁琐的重复性操作。另外,针对混合环境带来的应用交互与管理难题,一些容器管理服务/软件(如 SKS)还可帮助企业实现多个应用运行环境(如虚拟化和容器环境)的统一管理与网络互通。欲深入了解中国容器管理产品现状与挑战,请阅读:趋势分享|Gartner解读中国企业容器管理新挑战:混合环境、容器安全、AI支持。

容器-虚拟化融合

目前,企业内部虽然越来越倾向于以容器化的方式部署新的业务应用,但仍有不少应用系统需要运行在虚拟机上,如难以容器化改造的传统应用系统、容器化后会大大增加运维复杂度的一些有状态应用等。因此,不少用户会在未来 3-5 年内存在虚拟化与容器环境共存的情况。但这两个环境往往难以统一管理,应用网络也难以互联互通,资源使用也不能统一调度(详见往期文章),这些挑战就催生了两种主要的“容器-虚拟化融合”技术。

容器虚拟化(VM in Container)

在 Kubernetes 集群中创建、运行、管理虚拟机,以 KubeVirt 为代表。这种方案下,Kubernetes 部署在裸金属上,用户使用 Kubernetes API 对 Kubernetes 集群上的容器和虚拟机进行统一管理,降低学习成本。

虚拟化容器(Coexist)

在虚拟化环境中部署、运行、管理容器和虚拟机,以 VMware Tanzu 和 SmartX SKS 为代表。这种方案下,用户部署虚拟化/超融合平台运行虚拟机,Kubernetes 集群构建在其中一部分虚拟机之上,用户通过管理平台对 Kubernetes 集群和虚拟机进行统一管理。

容器虚拟化 vs 虚拟化容器

可以看到,“容器虚拟化”和“虚拟化容器”这两种方案的主要区别在于主要运行环境,具体架构对比见下图。根据 Gartner《容器技术成熟度曲线报告》,容器虚拟化方案仍处于技术起步期,距离成熟的市场应用还有很长(5-10 年)的时间,目前比较适合具备专业技术能力的用户在测试环境使用。而虚拟化容器方案不仅基于更成熟的虚拟化/超融合技术,而且具备更高的基础设施融合度、更广泛的高级虚拟化特性和设备支持,以及更稳定可靠的存储能力,因此更适合用户在现阶段采用,以支持生产环境中的虚拟化容器融合部署。

左:虚拟化容器方案 右:容器虚拟化方案

容器云(Cloud Container)

为了帮助用户更方便地获得容器优势、简化 IaaS 层的各种运维管理负担,一些厂商可以以云化交付的形式提供容器平台(一般包含 IaaS 层和 PaaS 层能力),用户可以基于符合兼容性的自有平台和设备部署容器云,在其上直接运行容器化应用,无需管理和运维容器基础架构层面的软硬件。常见的容器云包括 AWS、灵雀云等。

容器 vs 容器云 vs 容器管理

如前所述,容器是一种操作系统级别的虚拟化技术,为云原生/云计算提供敏捷能力,但容器本身可以在本地进行部署,并不一定以云的方式进行交付。“容器云”则是一个云化平台,以云的方式交付容器服务。一些容器云(PaaS)厂商可提供 IaaS 层容器管理的能力,用户也可使用 IaaS 厂商的容器管理服务/软件,以获取相对更完善的容器管理能力。

裸金属(Bare Metal)

裸金属是英文“Bare Metal”的直接翻译,有两种常见用法:

  • 裸金属服务器/裸金属云:云化交付的物理服务器,仅提供给单一用户/租户使用。裸金属服务器通常允许用户自行配置和管理操作系统、虚拟化层、中间件、应用层等,厂商负责提供、管理和运维裸金属物理服务器(含计算、存储和网络)。
  • 裸金属(Kubernetes 集群):在使用 Kubernetes 时,不少用户会将“裸金属”和“物理机”混淆使用,以“裸金属 Kubernetes 集群”表达采用物理机部署 Kubernetes 集群的意思。此时,“裸金属”仅表示以物理机作为运行环境,并不一定具备公有云属性。

裸金属 vs 物理机 vs 虚拟化

使用 Kubernetes 时,用户既可以将 Kubernetes 部署在物理机上,也可以部署在虚拟机上,两者的架构区别如下图所示。“裸金属 Kubernetes 集群”表达的含义与“物理机 Kubernetes 集群”相同。虚拟化和物理机环境运行 Kubernetes 在性能、稳定性、扩展能力、安全性、成本等方面都各有千秋,一些用户也可能会采用混合部署的方式,同时以物理机和虚拟机部署 Kubernetes 集群。欲深入了解两种部署环境的差异和混合部署的方案,请阅读:

  • 虚拟化 vs. 裸金属:K8s 部署环境架构与特性对比
  • 适合在虚拟化环境中部署 Kubernetes 的三个场景

 

为了帮助用户更简单、灵活、便捷地使用容器带来的各种优势,专业的现代化 IT 基础设施产品与解决方案提供商——志凌海纳 SmartX——推出了生产级容器管理与服务产品 SMTX Kubernetes 服务和虚拟化容器融合基础设施方案,帮助用户基于一套超融合基础设施实现虚拟机集群、虚拟机 Kubernetes 集群与物理机 Kubernetes 集群的统一管理,满足多种应用系统对于基础设施资源的不同需求。 

您还可点击下方链接,下载电子书《IT 基础架构团队的 Kubernetes 管理:从入门到评估》,了解更多 Kubernetes 管理与运维的干货知识! 

《IT 基础架构团队的 Kubernetes 管理:从入门到评估》icon-default.png?t=O83Ahttps://mobile.smartx.com/p/6c2769

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

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

相关文章

【Android】线程池的解析

引言 在Android当中根据用途分为主线程与子线程,主线程当中主要处理与界面相关的操作,子线程主要进行耗时操作。除了Thread本身以外,在Android当中还有很多扮演者线程的角色,比如AsyncTask( 底层为线程池,…

本地音乐服务器(三)

6. 删除音乐模块设计 6.1 删除单个音乐 1. 请求响应设计 2. 开始实现 首先在musicmapper新增操作 Music findMusicById(int id);int deleteMusicById(int musicId); 其次新增相对应的.xml代码&#xff1a; <select id"findMusicById" resultType"com.exa…

Spring Boot图书馆管理系统:疫情中的管理利器

摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了疫情下图书馆管理系统的开发全过程。通过分析疫情下图书馆管理系统管理的不足&#xff0c;创建了一个计算机管理疫情下图书馆管理系统的方案。文章介绍了疫情下图…

集群聊天服务器(7)数据模块

目录 Mysql数据库代码封装头文件与源文件 Mysql数据库代码封装 业务层代码不要直接写数据库&#xff0c;因为业务层和数据层的代码逻辑也想完全区分开。万一不想存储mysql&#xff0c;想存redis的话&#xff0c;就要改动大量业务代码。解耦合就是改起来很方便。 首先需要安装m…

Linux第93步_Linux内核的LED灯驱动

Linux内核的LED灯驱动采用platfomm框架&#xff0c;因此我们只需要按照要求在“设备树文件”中添加相应的LED节点即可。 1 、通过“linux内核图形化配置界面”令“CONFIG_LEDS_GPIOy” 1)、打开终端&#xff0c;输入“cd linux/atk-mp1/linux/my_linux/linux-5.4.31/回车”&a…

Zmap+python脚本+burp实现自动化Fuzzing测试

声明 学习视频来自 B 站UP主泷羽sec&#xff0c;如涉及侵权马上删除文章。 笔记的只是方便各位师傅学习知识&#xff0c;以下网站只涉及学习内容&#xff0c;其他的都与本人无关&#xff0c;切莫逾越法律红线&#xff0c;否则后果自负。 ✍&#x1f3fb;作者简介&#xff1a;致…

红外相机和RGB相机外参标定 - 无需标定板方案

1. 动机 在之前的文章中红外相机和RGB相机标定&#xff1a;实现两种模态数据融合_红外相机标定-CSDN博客 &#xff0c;介绍了如何利用标定板实现外参标定&#xff1b;但实测下来发现2个问题&#xff1a; &#xff08;1&#xff09;红外标定板尺寸问题&#xff0c;由于标定板小…

android:taskAffinity 对Activity退出时跳转的影响

android:taskAffinity 对Activity跳转的影响 概述taskAffinity 的工作机制taskAffinity对 Activity 跳转的影响一个实际的开发问题总结参考 概述 在 Android 开发中&#xff0c;任务栈&#xff08;Task&#xff09;是一个核心概念。它决定了应用程序的 Activity 如何相互交互以…

Ubuntu常见命令

关于export LD_LIBRARY_PATHcmake默认地址CMakelists.txt知识扩充/home&#xff1a;挂载新磁盘到 /home 子目录 关于export LD_LIBRARY_PATH 程序运行时默认的依赖库的位置包括lib, /usr/lib ,/usr/local/lib 通过命令export LD_LIBRARY_PATHdesired_path:$LD_LIBRARY_PATH追加…

时间类的实现

在现实生活中&#xff0c;我们常常需要计算某一天的前/后xx天是哪一天&#xff0c;算起来十分麻烦&#xff0c;为此我们不妨写一个程序&#xff0c;来减少我们的思考时间。 1.基本实现过程 为了实现时间类&#xff0c;我们需要将代码写在3个文件中&#xff0c;以增强可读性&a…

php交友源码交友系统源码相亲交友系统源码php社交系统php婚恋源码php社区交友源码vue 仿交友社交语聊技术栈

关于PHP交友、相亲、婚恋、社区交友系统的源码以及Vue仿交友社交语聊技术栈&#xff0c;以下是一些详细信息和建议&#xff1a; 一、PHP交友系统源码 系统架构设计 前端展示层&#xff1a;负责向用户提供直观友好的界面&#xff0c;包括注册登录页面、个人资料页面、匹配页面、…

Java小技艺

使用bat文件启动jar包 平时在工作中运行jar包一般是导出后命令行窗口运行 jar -jar xxx.jar 这个其实是很不方便的。可以在win上编写bat脚本去运行jar包的。 1 编写bat脚本 start jre8/bin/javaw -jar xxxx.jar2 将jre和待执行的jar包存放到一个目录下(和bat文件在同一目录…

蓝桥杯第22场小白入门赛2~5题

这场比赛开打第二题就理解错意思了&#xff0c;还以为只能用3个消除和5个消除其中一种呢&#xff0c;结果就是死活a不过去&#xff0c;第三题根本读不懂题意&#xff0c;这蓝桥杯的题面我只能说出的是一言难尽啊。。第四题写出来一点但是后来知道是错了&#xff0c;不会正解&am…

‘视’不可挡:OAK相机助力无人机智控飞行!

南京邮电大学通达学院的刘同学用我们的oak-d-lite实现精确打击无人机的避障和目标识别定位功能&#xff0c;取得了比赛冠军。我们盼望着更多的朋友们能够加入到我们OAK的队伍中来&#xff0c;参与到各式各样的比赛中去。我们相信&#xff0c;有了我们相机的助力&#xff0c;大家…

最小生成树——Kruskal、Prim算法

图的存储&#xff1a; 高阶数据结构——图 文章目录 目录 文章目录 一、kruskal算法 二、Prim算法 前言 连通图中的每一棵生成树&#xff0c;都是原图的一个极大无环子图&#xff0c;即&#xff1a;从其中删去任何一条边&#xff0c;生成树 就不在连通&#xff1b;反之&#xf…

集群聊天服务器(9)一对一聊天功能

目录 一对一聊天离线消息服务器异常处理 一对一聊天 先新添一个消息码 在业务层增加该业务 没有绑定事件处理器的话消息会派发不出去 聊天其实是服务器做一个中转 现在同时登录两个账号 收到了聊天信息 再回复一下 离线消息 声明中提供接口和方法 张三对离线的李…

华为再掀技术革新!超薄膜天线设计路由器首发!

随着Wi-Fi技术的不断进步&#xff0c;新一代的Wi-Fi 7路由器凭借其高速率、低延迟、更稳定的性能受到了广泛关注。它能够更好地满足现代家庭对网络性能的高要求&#xff0c;带来更加流畅、高效的网络体验。9月24日&#xff0c;华为在其秋季全场景新品发布会上推出了全新Wi-Fi 7…

【阅读记录-章节2】Build a Large Language Model (From Scratch)

目录 2.Working with text data2.1 Understanding word embeddings2.2 Tokenizing text通过一个简单的实验来理解文本的词元化概念关键概念 2.3 Converting tokens into token IDs实现分词器类&#xff08;Tokenizer Class&#xff09;应用分词器测试文本的编码与解码通过分词器…

SDF,一个从1978年运行至今的公共Unix Shell

关于SDF 最近发现了一个很古老的公共Unix Shell服务器&#xff0c;这个项目从1978年运行至今&#xff0c;如果对操作系统&#xff0c;对Unix感兴趣&#xff0c;可以进去玩一玩体验一下 SDF Public Access UNIX System - Free Shell Account and Shell Access 注册方式 我一…

关于Qt C++中connect的几种写法

目录 1. 传统的槽函数写法 2. 使用函数指针的connect写法&#xff08;5.0&#xff09; 3. Lambda表达式作为槽函数&#xff08;C11&#xff09; 4.使用QOverload选择重载信号的写法 这connect函数就像是编程世界里的“茴”字&#xff0c;千变万化&#xff0c;各有千秋。咱们…