首页 > 其他分享 >虚拟化技术[1]之服务器虚拟化

虚拟化技术[1]之服务器虚拟化

时间:2024-05-25 22:29:58浏览次数:22  
标签:虚拟化 虚拟机 技术 VM 内存 服务器 迁移

文章目录

虚拟化技术简介

  • 虚拟化技术伴随着计算机的出现而产生和发展起来,虚拟化技术可以用来对数据中心的各种资源进行虚拟化和管理,可以实现服务器虚拟化、存储虚拟化、网络虚拟化和桌面虚拟化。虚拟化技术已经成为构建云计算环境的一项关键技术。
  • 虚拟化技术将数据中心的物理资源进行抽象整合。数据中心虚拟化可以实现资源的动态分配和调度,提高现有资源的利用率和服务可靠性;提供自动化的服务开通能力,降低运维成本;具有有效的安全机制和可靠性机制,满足公众客户和企业客户的安全需求;同时也可以方便系统升级、迁移和改造。

数据中心虚拟化

  • 服务器虚拟化:将一个或多个物理服务器虚拟成多个逻辑上的服务器
  • 存储虚拟化:把分布的异构存储设备统一为一个或几个大的存储池
  • 网路虚拟化:在底层物理网络和网络用户之间增加一个抽象层

服务器虚拟化

服务器虚拟化层次

寄居虚拟化

  • 寄居虚拟化的虚拟化层一般称为虚拟机监控器(VMM)。
  • 系统损耗比较大
  • 操作系统层的虚拟化,没有独立的Hypervisor层
  • 使用操作系统层虚拟化,所有虚拟服务器必须运行同一操作系统
    在这里插入图片描述

裸机虚拟化

  • 架构中的VMM也可以认为是一个操作系统,一般称为Hypervisor
  • Hypervisor实现从虚拟资源到物理资源的映射
  • Hypervisor实现不同虚拟机的运行上下文保护与切换,保证了各个客户虚拟系统的有效隔离
    在这里插入图片描述

VMM无法直接捕获特权指令解决方案

在这里插入图片描述

  • 完全虚拟化具有较好兼容性,在服务器虚拟化中应用广泛
  • 半虚拟化技术降低由于虚拟化而引入的系统性能损失

服务器虚拟化底层实现

CPU虚拟化

  1. 虚拟CPU的正确运行要保证虚拟机指令正确运行,现有的实现技术包括模拟执行和监控执行
  2. 调度问题是指VMM决定当前哪个虚拟CPU在物理CPU上运行,要保证隔离性、公平性和性能

在这里插入图片描述

内存虚拟化

  • 内存虚拟化技术:物理内存统一管理,包装成多个虚拟的物理内存提供给若干虚拟机使用,每个虚拟机拥有各自独立的内存空间。
  • 虚拟内存的管理包括3种地址:机器地址、物理地址、虚拟地址
    在这里插入图片描述
  1. 虚拟地址(Virtual Address):

    • 由应用程序生成的地址。虚拟地址空间独立于物理内存,因此每个进程认为自己拥有一个连续且独立的地址空间。
    • 虚拟地址通过内存管理单元(MMU)进行映射,转换为物理地址。
  2. 物理地址(Physical Address):

    • 实际存在于内存中的地址。物理内存是真实硬件提供的存储空间。
    • 操作系统和硬件联合负责将虚拟地址翻译成物理地址,以便进行实际的存储操作。
  3. 机器地址(Machine Address):

    • 机器地址有时也指物理地址,两者在大多数上下文中是同义的。
    • 在某些特定的硬件架构或文档中,机器地址可能特指硬件层面的一些特殊地址,然而普遍理解是物理地址。

I/O设备虚拟化

  • I/O设备虚拟化技术把真实的设备统一管理起来,包装成多个虚拟设备给若干个虚拟机使用,响应每个虚拟机的设备访问请求和I/O请求
  • I/O设备虚拟化同样是由VMM进行管理,主要有全虚拟化、半虚拟化和软件模拟三种思路。
  1. 全虚拟化(Full Virtualization):

    • 在全虚拟化中,VMM模拟真实的硬件设备,使得虚拟机中的操作系统和应用程序可以完全不知道自己运行在虚拟化环境中。
    • 优点是兼容性好,不需要修改客户操作系统。然而,由于需要模拟硬件,可能会导致性能下降
  2. 半虚拟化(Paravirtualization):

    • 半虚拟化通过修改客户操作系统,使其意识到自己运行在虚拟化环境中,并提供特殊的API来优化I/O操作。
    • 这种方法可以显著提高I/O性能,但需要对客户操作系统进行修改,这可能会限制其应用范围。
  3. 软件模拟(Software Emulation):

    • 软件模拟是通过软件完全模拟硬件设备的行为。这种方法可以在任何硬件上运行任何操作系统,但通常性能较低
    • 软件模拟常用于测试和开发环境,或者在需要支持多种不同操作系统的场景中

虚拟机迁移

  • 虚拟机迁移:将虚拟机实例从源宿主机迁移到目标宿主机,并且在目标宿主机上能够将虚拟机运行状态恢复到其在迁移之前相同的状态,以便能够继续完成应用程序的任务。
    在这里插入图片描述

虚拟机动态迁移

  • 实时迁移(LiveMigration):保持虚拟机运行的同时,把它从一个计算机迁移到另一个计算机,并在目的计算机恢复运行的技术。
  1. 当云计算中心的物理服务器负载过大时,管理员可以将其上面的虚拟机迁移到其他服务器,达到负载平衡
  2. 云计算中心的物理服务器需要定期进行升级维护,当升级维护服务器时,管理员可以将其上面的虚拟机迁移到其他服务器,等升级维护完成之后,再把虚拟机迁移回来
    在这里插入图片描述
    在这里插入图片描述
  3. 预迁移(Pre-Migration):主机A打算迁移其上的一个虚拟机VM,首先选择一个目的计算机。
  4. 预定资源(Reservation):主机A向主机B发起迁移请求,先确认B是否有必需的资源,若有,则预定这些资源;若没有,VM仍在主机A中运行,可以继续选择其他计算机作为目的计算机。
  5. 预复制(InterativePre-Copy):在这一阶段VM仍然运行,主机A以迭代的方式将VM的内存页复制到主机B上。在第一轮迭代中,所有的页都要从A传送到B,以后的迭代只复制前一轮传送过程中被修改过的页面。
  6. 停机复制(Stop-and-Copy):停止主机A上的VM,把它的网络连接重定向到B。CPU状态和前一轮传送过程中修改过的页都在这个步骤被传送。最后,主机A和主机B上有一致的VM映象。
  7. 提交(Commitment):主机B通知A已经成功收到了VM的映像,主机A对这个消息进行确认,然后主机A可以抛弃或销毁其上的VM。
  8. 启动(Activation):启动迁移到B上的VM,迁移后使用目的计算机的设备驱动,广播新的IP地址。

迁移内容:内存迁移

  • 为实现虚拟机的实时迁移,完整的内存迁移的过程分为以下三个阶段:
  1. 第一阶段:Push阶段。在VM运行的同时,将它的一些内存页面通过网络复制到目的机器上。为了保证内容的一致性,被修改过的页需要重传。
  2. 第二阶段:Stop-and-Copy阶段。VM停止工作,把剩下的页面复制到目的计算机上,然后在目的计算机上启动新的VM。
  3. 第三阶段:Pull阶段。新的虚拟机运行过程中,如果访问到未被复制的页面,就会出现页错误并从原来的VM处把该页复制过来。
  • 实际上,目前大部分的迁移策略只包含其中的一个或者两个阶段。

在这里插入图片描述

迁移内容:网络资源迁移

  • 虚拟机这种系统级别的封装方式意味着迁移时VM的所有网络设备,包括协议状态(如TCP连接状态)以及IP地址都要随之一起迁移。

  • 在局域网内,可以通过发送ARP重定向包,将VM的IP地址与目的机器的MAC地址相绑定,之后的所有包就可以发送到目的机器上。

迁移内容:存储设备迁移

  • 迁移存储设备的最大障碍在于需要占用大量时间和网络带宽,通常的解决办法是以共享的方式共享数据和文件系统,而非真正迁移。
  • 目前大多数集群使用NAS(Network Attached Storage,网络连接存储)作为存储设备共享数据。
  • NAS实际上是一个带有瘦服务器的存储设备,其作用类似于一个专用的文件服务器。
  • 在局域网环境下,NAS已经完全可以实现异构平台之间,如NT、UNIX等的数据级共享。
  • 基于以上的考虑,Xen并没有实现存储设备的迁移,实时迁移的对象必须共享文件系统。

隔离技术

  • 虚拟机隔离指虚拟机之间在没有授权许可的情况下,互相之间不可通信、不可联系的一种技术。
    • 从软件角度,互相隔离的虚拟机之间保持独立,如同一个完整的计算机
    • 从硬件角度,被隔离的虚拟机相当于一台物理机,有自己的CPU、内存、硬盘、I/O等,它与宿主机之间保持互相独立的状态
    • 从网络角度,被隔离的虚拟机如同物理机一样,既可以对外提供网络服务,也可以从外界接受网络服务
  • 虚拟机隔离是确保虚拟机之间安全与可靠性的一种重要手段,现有虚拟机隔离机制主要包括:网络隔离;构建虚拟机安全文件防护网;基于访问控制的逻辑隔离机制;通过硬件虚拟,让每个虚拟机无法突破虚拟机管理器给出的资源限制

内存隔离

在这里插入图片描述

  • MMU(Memory Management Unit 内存管理单元),它是中央处理器(CPU)中用来管理虚拟存储器、物理存储器的控制线路,负责将虚拟地址映射为物理地址,以及提供硬件机制的内存访问授权

  • Xen将这层中间地址真正地映射到机器地址上却可以是不连续的,这保证所有的物理内存可被任意分配给不同的Guest OS
    在这里插入图片描述


  • 虚拟机监控器使用分段和分页机制对自身的物理内存进行保护。x86体系结构提供支持分段机制的虚拟内存,这能够提供另一种形式的特权级分离。

  • 基址:基址+虚拟地址=>线性地址
  • 段限:决定段中所能访问的线性空间的长度
  • 属性位:标记是否可读写、可执行、属于代码段还是数据段

网络隔离

  • 网络隔离:确保把有害的攻击隔离,在可信网络之外和保证可信网络内部信息不外泄的前提下,完成网间数据的安全交换。
  • 网络隔离关键:在于系统对通信数据的控制,即通过不可路由的协议来完成网间的数据交换

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

标签:虚拟化,虚拟机,技术,VM,内存,服务器,迁移
From: https://blog.csdn.net/yang2330648064/article/details/139185669

相关文章

  • [集群聊天服务器]----(四)MySQL数据库模块
    上一节我们对网络模块和业务模块进行了解耦[集群聊天服务器]----(三)ChatService模块,解耦网络模块和业务模块,封装了回调函数。在项目中需要使用mysql数据库进行存储用户重要数据,并进行增删改查操作。,所以这一节我们对mysql的封装使用进行剖析,这里使用db类进行封装。数据库......
  • [技术报告]InternLM2 Technical Report
    摘要像ChatGPT和GPT-4这样的大型语言模型(llm)的进化引发了人们对人工通用智能(AGI)出现的讨论。然而,在开源模型中复制这种进步一直是一个挑战。本文介绍了InternLM2,这是一个开源的大语言模型,通过创新的预训练和优化技术,在6个维度和30个基准的综合评估、长上下文建模和开放式主......
  • 大数据技术原理(二):搭建hadoop伪分布式集群这一篇就够了
    (实验一搭建hadoop伪分布式)--------------------------------------------------------------------------------------------------------------------------------一、实验目的1.理解Hadoop伪分布式的安装过程实验内容涉及Hadoop平台的搭建和配置,旨在提高对大数据处理框......
  • PyCharm连接远程服务器
    从仓库拉取代码1.新建一个文件夹用来放置你从仓库里拉取的代码,在你新建的文件夹目录下打开GitBash,输入gitclone地址2.用PyCharm打开你的项目文件在服务器上也拉取一份项目文件输入的命令就是sshvisionx@服务器地址;然后接着输入gitclone地址就好了,这样就在服务器上也拷贝......
  • 信号处理技术:现代通信技术的基石
    随着信息技术的飞速发展,通信技术的每一次革新都极大地改变了人们的生活方式。而在这背后,信号处理技术作为通信技术的核心,通过深入分析信号特性、提取有用信息、转换信号形式等一系列手段,为现代通信技术的发展提供了强有力的支持。一、信号处理技术的核心概念信号处理技术,简而言......
  • 服务器端口号怎么看?如何查看服务器端口号呢?有哪些需要注意的?
    简单来说,端口号就是计算机与外界通讯交流的出口,每个端口都有不同的编号,也就是“端口号”。它们是唯一的,用于标识不同的服务和应用程序。通过端口号,我们可以知道哪些服务正在运行,以及如何与它们进行通信。那么,如何查看服务器端口号呢?以下是一些常用的方法:一、通过命令行查看......
  • Rust腐蚀怎么用服务器一键开服联机教程
    1、进入控制面板首次登陆需要点击下方重置密码,如何再点击登录面板,点击后会跳转到登录页面,输入用户名和密码登录即可2、设置游戏端口由于腐蚀的设置需要三个端口,它们用于游戏端口(必须为首选端口),查询端口,RCON端口服务器创建时默认会获得一个首选端口,既为我们的游戏端口......
  • 克隆不再是梦:数字孪生技术让复制变得轻而易举
    数字孪生技术正在引领一个新时代,它允许我们将现实世界的物理实体以数字形式复制和模拟,实现物理空间与数字空间的实时双向同步映射及虚实交互。这种技术的应用范围广泛,从制造业到医疗健康,从城市规划到娱乐产业,都正在被数字孪生技术所改变。数字孪生的关键技术数字孪生的实现......
  • 网络安全(黑客技术)2024小白自学必看手册
    一、怎样规划网络安全如果你是一个安全行业新人,我建议你先从网络安全或者Web安全/渗透测试这两个方向先学起,一、是市场需求量高二、则是发展相对成熟入门比较容易值得一提的是,学网络安全,是先网络后安全;学Web安全,也是先Web再有安全。安全不是独立存在的,而是建立在其......
  • 抄表系统厂家:创新技术与解决方案的引领者
    1.技术创新:智能化抄表系统的兴起随着时代的发展,传统式手动抄水表方法已慢慢被智能化抄表系统所替代。抄表系统厂家在这一领域扮演了重要角色,她们产品研发智能抄表系统运用物联网技术、大数据和云计算等先进技术,完成了远程控制智能抄表,大大的提高了效率并降低了人为失误。这类......