【面试题】简单聊一下什么是云原生、什么是k8s、容器,容器与虚机相比优势

embedded/2025/1/12 23:35:02/
  1. 云原生(Cloud Native)
    • 定义云原生是一种构建和运行应用程序的方法,旨在充分利用云计算的优势。它涵盖了一系列技术和理念,包括容器化、微服务架构、自动化部署与管理等。
    • 特点云原生应用程序被设计为可弹性扩展、容错性强,能够快速响应变化。例如,一个电商平台的云原生应用可以根据用户流量自动调整资源,在促销活动期间增加服务器资源来处理更多订单,活动结束后减少资源以节省成本。同时,它通过微服务架构将应用拆分成多个小型、独立的服务,每个服务可以独立开发、部署和更新,提高了开发和运维的效率。
  2. Kubernetes(K8s)
    • 定义:Kubernetes 是一个开源的容器编排平台,用于自动化容器化应用的部署、扩展和管理。它可以理解为容器的“大管家”。
    • 功能:K8s 提供了诸如自动部署容器到集群节点、负载均衡、自动伸缩以及滚动更新等功能。例如,当一个 Web 应用需要从 3 个实例扩展到 5 个实例时,K8s 可以自动完成这个过程,确保新的容器实例正确部署并加入到服务中,同时将流量均匀地分配到各个实例上。而且在进行软件版本更新时,K8s 支持滚动更新,即逐步替换旧版本的容器为新版本,避免一次性更新导致的服务中断。
  3. 容器(Container)
    • 定义容器是一种轻量级的、可执行的独立软件包,它包含了运行应用程序所需的所有内容,如代码、运行时环境、系统工具、系统库等。每个容器都可以看作是一个独立的“小盒子”,里面封装了应用及其依赖。
    • 原理容器基于操作系统的内核特性,如 Linux 命名空间(Namespaces)和控制组(cgroups)实现资源隔离和限制。例如,不同的容器可以有各自独立的文件系统、网络空间等,相互之间不会干扰。同时,控制组可以限制容器对 CPU、内存等资源的使用量。
  4. 容器与虚拟机相比的优势
    • 启动速度
      • 容器:启动速度极快,通常在秒级甚至毫秒级。这是因为容器共享宿主机的操作系统内核,启动时只需加载容器内的应用和相关配置。例如,一个基于容器的 Web 应用可以在几秒钟内启动并对外提供服务。
      • 虚拟机:启动时间较长,一般需要数十秒甚至几分钟。虚拟机需要加载完整的操作系统镜像,包括内核、驱动等,这一过程较为耗时。
    • 资源占用
      • 容器:资源占用少,因为容器共享宿主机的操作系统内核,只需要额外占用应用运行所需的资源,如代码、库文件等。例如,多个容器化的应用可以在同一台物理机上高效运行,每个容器仅占用少量的内存和 CPU 资源。
      • 虚拟机:资源占用多,每个虚拟机都需要独立的操作系统镜像,包括内核、驱动、系统文件等,即使应用本身很小,也需要占用大量的磁盘空间和内存等资源。
    • 灵活性和可移植性
      • 容器:灵活性高,可移植性强。容器可以在不同的操作系统环境(只要内核支持)中运行,无论是在物理机、虚拟机还是公有云、私有云环境,都能保持一致的运行状态。例如,开发人员在本地开发环境中创建的容器,可以直接部署到生产环境的云服务器上,无需过多修改。
      • 虚拟机:可移植性相对较差,由于虚拟机包含了特定的操作系统镜像和硬件配置信息,在不同的硬件环境或云平台上迁移时,可能会遇到兼容性问题,需要进行额外的配置和调整。

http://www.ppmy.cn/embedded/153408.html

相关文章

2025广州国际汽车内外饰技术展览会:引领汽车内外饰发展新潮流-Automotive Interiors

随着科技的不断进步和消费者对汽车品质的要求日益提高,汽车内外饰的设计和制造也在不断创新和发展。AUTO TECH China 2025广州国际汽车内外饰技术展览会作为行业内的重要盛会,将于2025年11月20日至22日在广州保利世贸博览馆盛大举办。本次展览会将汇集全…

51单片机——串口通信(重点)

1、通信 通信的方式可以分为多种,按照数据传送方式可分为串行通信和并行通信; 按照通信的数据同步方式,可分为异步通信和同步通信; 按照数据的传输方向又可分为单工、半双工和全双工通信 1.1 通信速率 衡量通信性能的一个非常…

小识MySQL中当前读CR和快照读SR

在MySQL中,尤其是使用InnoDB存储引擎时,存在两种主要的读取方式:当前读(Current Read)和快照读(Snapshot Read)。以下是关于这两种读取方式的详细解释和对比: 一、快照读&#xff0…

Django Admin中添加自定义按钮与默认按钮并列

引言 在Django Admin中,我们经常需要添加自定义操作按钮,以便管理员可以快速执行特定任务。本文将介绍如何在Django Admin中添加一个自定义按钮(如"同步ECR仓库"),并将其与默认的"添加"、"删除"按钮放在同一级别。 © ivwdcwso (ID: u01217…

【架构设计】新闻推送系统设计

系统需求与估算 功能需求:包括提要发布、检索、通知和分析等功能。非功能需求:需具备高可用性和低延迟特性。估算数据:假设每天有 2000 万活跃用户,每人每天调整五次,由此可得每秒约接收 1000 条推文,按 10…

oracle闪回恢复数据:(闪回查询,闪回表,闪回库,回收站恢复)

oracle的闪回查询,可以查询提交在表空间的闪回数据,并可以还原所查询的数据,用于恢复短时间内的delele 或者 update 误操作,非常方便,缺点是只能恢复大概几小时内的数据。 文章目录 概要闪回查询恢复数据的主要方法包括…

SpringBoot的@Scheduled和@Schedules有什么区别

Scheduled 的详细解析 参数详解 cron: 使用Cron表达式来指定复杂的调度模式。Cron表达式的格式如下: 秒(0-59)分钟(0-59)小时(0-23)日(1-31)月(1-12 或 JAN-…

哈希表及模拟实现

目录 一、哈希表的概念 二、模拟实现哈希表 1.开放地址法 (1)哈希表的数据加上状态标志 (2)哈希表扩容:载荷因子 (3)哈希函数:不同数据类型转换为整型 (4)完整代码 2.链地址法(哈希桶) (1)哈希表扩容:载荷因子…