物理机、虚拟机、容器的比较(一)

本文介绍了虚拟化技术的基础概念,包括虚拟机与容器的区别、虚拟化技术的优势以及虚拟化技术框架等内容。通过对比物理机、虚拟机和容器,阐述了虚拟化技术如何提高资源利用率、降低管理成本并增强系统的灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

俗话说,学好虚拟化走遍宇宙都不怕,但对于计算机方面的初学者,肯定很多人都好奇为什么要使用虚拟机和容器,而不是直接使用多进程来运行多个业务。下面Mr chen就带大家一起浅谈浅谈三者的区别。

首先用三张图很直观的表示三者的区别。

一、物理机


二、虚拟机


三、容器


(一)虚拟机技术概况

定义:

虚拟化,是指通过虚拟化技术将一台计算机虚拟为多台逻辑计算机。在一台计算机上同时运行多个逻辑计算机,每个逻辑计算机可运行不同的操作系统,并且应用程序都可以在相互独立的空间内运行而互不影响,从而显著提高计算机的工作效率。--百度词条

虚拟化是表示计算机资源的逻辑组(或子集)的过程,这样就可以用从原始配置中获益的方式访问它们。这种资源的新虚拟视图并不受实现、地理位置或底层资源的物理配置的限制。 -- Wikipedia

虚拟化技术可针对具体应用目的创建特定目的的虚拟环境,安全、效率高,快照、克隆、备份、迁移等方便。系统虚拟化是将一台物理计算机虚拟成一台或多台虚拟计算机系统,每个都有自己的虚拟硬件,其上的操作系统任认为自己运行在一台独立的主机上,计算机软件在一个虚拟的平台上而不是真实的硬件平台上运行。虚拟化技术可以扩大硬件的容量,简化软件的重新配置过程。其中CPU的虚拟化可以单CPU模拟多CPU并行运行,允许一个平台同时运行多个操作系统,并且应用程序可以在相互独立的空间内运行而互不影响。虚拟化技术在降低硬件成本的同时,还可以显著提高系统的工作效率和安全性。

虚拟化系统的实现通常是在操作系统和硬件之间加入一个虚拟机监控程序,称为Hypervisor(如图所示)。由Hypervisor主要负责各个操作系统之间的硬件资源协调。虚拟机监控程序是一种特殊操作系统,直接在裸机上运行(针对完全虚拟化技术)。虚拟机监控程序创建一个底层硬件平台抽象,一个或多个虚拟机(VM)共享这个底层硬件平台。在这种环境中,VM只是操作系统及其应用程序的容器,一个 VM 与虚拟机监控程序上运行的其他 VMs 隔离,这支持多个操作系统或多个配置不同的相似操作系统。


图1 虚拟化系统结构

1.虚拟计算机系统三层含义-同质、高效、资源受控。
同质-
本质上虚拟机和物理机是相同的、表现上有所差异,如一个物理核虚拟多个核。
高效-虚拟机效能接近物理机。
资源受控-虚拟机对系统资源有完全的控制能力,包括分配、管理、回收。
2.虚拟化分不同层面的虚拟化
硬件抽象层的虚拟化
-客户机与宿主机硬件相似,指令集相似。
操作系统层虚拟化-内核可以提供多个相互隔离的用户态,其拥有独立的文件系统、网络、系统设置和库函数。
库函数层初始化-是不同的操作系统可以拥有共同的库函数接口,应用程序不需修改。

编程语言层虚拟化-编的程序运行在一个虚拟机上,与具体硬件无关。如Java。

3.虚拟机的优点
良好的封装
-虚拟机的运行环境保持便捷,便于随时抓取状态、备份、克隆、挂起和恢复。
多实例-最大限度减少物理资源,提高利用率,便于管理。
隔离-每个应用程序可以再独立的操作系统中运行,互不干涉,崩溃也不会影响其他任务。
硬件无关性-只要拥有相同的硬件抽象层,虚拟机就可以无缝迁移,因此维护和升级简单。
安全-便于控制访问权利,病毒入侵检测等。
4.虚拟化分类
按照虚拟化程度分完全虚拟化类虚拟化完全虚拟化-客户及操作系统不需要任何修改即可运行,分软件辅助完全虚拟化和硬件辅助完全虚拟化,完全虚拟化能够模拟所有CPU指令。
类虚拟化-操作系统需要做出适应性修改,回避那些难以模拟的指令。

按照宿主机是否存在独立操作系统分为hypervisor模型和宿主模型,前者需支持所有的物理资源管理(系统启动、内存管理、设备驱动等),效率高、复杂;后者只需调用宿主操作系统API实现虚拟化,宿主操作系统可以是windows、linux,效率低、简单。第三类是两者的混和,VMM位于硬件层之上,但让出部分IO设备管理权给一个运行在特权虚拟机上的特权操作系统,VMM负责处理器和内存虚拟化。

(二)虚拟化技术框架

虚拟环境组成:硬件、VMM、虚拟机,物理机中操作系统直接管理硬件(通过硬件抽象层HAL),虚拟环境中VMM管理硬件(会构建一个或多个逻辑HAL),操作系统运行在VMM 逻辑HAL之上,运行在非CPU最高特权。

对物理资源虚拟的三个主要任务:处理器虚拟化、内存虚拟化和I/O虚拟化。若硬件直接支持虚拟化技术则CPU辅助完成虚拟化过程,在CPU、芯片组以及IO设备等加入专门针对虚拟化的支持,从而高容易、高效的实现虚拟化。

(三)为什么选择虚拟化

虚拟化技术的优势:
1.更高的资源利用率——虚拟可支持实现物理资源和资源池的动态共享,提高资源利用率,特别是针对那些平均需求远低于需要为其提供专用资源的不同负载。
2.降低管理成本——虚拟可通过以下途径提高工作人员的效率:减少必须进行管理的物理资源的数量;隐藏物理资源的部分复杂性;通过实现自动化、获得更好的信息和实现中央管理来简化公共管理任务;实现负载管理自动化。另外,虚拟还可以支持在多个平台上使用公共的工具。
3.提高使用灵活性——通过虚拟可实现动态的资源部署和重配置,满足不断变化的业务需求。
4.提高安全性——虚拟可实现较简单的共享机制无法实现的隔离和划分,这些特性可实现对数据和服务进行可控和安全的访问。
5.更高的可用性——虚拟可在不影响用户的情况下对物理资源进行删除、升级或改变。
6.更高的可扩展性——根据不同的产品,资源分区和汇聚可支持实现比个体物理资源小得多或大得多的虚拟资源,这意味着您可以在不改变物理资源配置的情况下进行规模调整。
7.互操作性和投资保护——虚拟资源可提供底层物理资源无法提供的与各种接口和协议的兼容性。
8.改进资源供应——与个体物理资源单位相比,虚拟能够以更小的单位进行资源分配。

### 使用 VirtualBox 将物理机转换为虚拟机 #### 物理机虚拟机(P2V)的概念 物理机虚拟机 (P2V, Physical-to-Virtual) 是指将现有的物理计算机上的操作系统及其应用程序迁移到虚拟环境中运行的过程。此过程允许保留原始系统的全部功能,但在虚拟化平台上执行。 #### 准备工作 为了成功完成 P2V 转换,在开始之前需准备如下事项: - 安装有 Oracle VM VirtualBox 的目标机器[^1]。 - 确认有足够的磁盘空间来容纳新创建的虚拟硬盘文件。 - 获取并准备好要迁移的操作系统映像或备份工具。 #### 方法:通过第三方软件辅助迁移 种常见的方式是利用专门设计用于此类任务的应用程序来进行迁移操作。这些应用可以简化整个流程,并提供额外的功能如自定义分区布局等。然而这种方法通常涉及商业产品,可能不适合所有人。 另种更为经济实惠的选择是从零重新部署个新的虚拟环境然后手动复制数据过去;虽然耗时较长但也更加灵活可控。 #### 方法二:基于克隆技术的手动迁移 对于熟悉 Linux 命令行界面和技术细节较高的用户来说,可以直接采用命令行方式借助 `dd` 工具配合 SSH 或者其他远程连接手段实现跨平台的数据镜像转移。这种方式要求源端和目的端都能够正常启动进入最小化的 shell 接口以便于执行必要的指令集。 具体步骤包括但不限于: 1. 创建新的 VDI 文件作为未来虚拟机的基础存储介质; 2. 利用网络传输机制(例如 SCP/SFTP),把实际硬件驱动器的内容逐位读取并通过管道传递给远端等待写入的新容器内; 3. 修改引导加载程序配置使得能够在模拟环境下顺利开机; 4. 配置网络接口参数确保内外部通信畅通无阻[^2]。 需要注意的是上述两种方案都存在定的风险性和复杂度,建议仅当具备充分的技术背景知识后再尝试实施。此外还应该提前做好完整的系统快照或者定期增量备份以防意外情况发生造成不可逆损失。 ```bash # 示例代码片段展示如何使用 dd 和 ssh 进行低级磁盘拷贝 ssh user@source-machine "sudo dd if=/dev/sda bs=64K | gzip -1 -" | gunzip - | sudo dd of=/path/to/new.vdi bs=64K ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值