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

文章目录

  • 虚拟化技术简介
    • 数据中心虚拟化
  • 服务器虚拟化
    • 服务器虚拟化层次
      • 寄居虚拟化
      • 裸机虚拟化
      • VMM无法直接捕获特权指令解决方案
    • 服务器虚拟化底层实现
      • CPU虚拟化
      • 内存虚拟化
      • I/O设备虚拟化
    • 虚拟机迁移
      • 虚拟机动态迁移
      • 迁移内容:内存迁移
      • 迁移内容:网络资源迁移
      • 迁移内容:存储设备迁移
    • 隔离技术
      • 内存隔离
      • 网络隔离

虚拟化技术简介

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

数据中心虚拟化

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

服务器虚拟化

服务器虚拟化层次

寄居虚拟化

  • 寄居虚拟化的虚拟化层一般称为虚拟机监控器(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体系结构提供支持分段机制的虚拟内存,这能够提供另一种形式的特权级分离。

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

网络隔离

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

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

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

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

相关文章

小短片创作-组装场景(一)

1、项目基础设置 通过第三人称模板,创建1个项目 1.自动曝光:关闭,因为要做专业的小短片,曝光需要手动控制。 2.扩展自动曝光中的默认亮度范围:启用 3.全局光照系统:选择屏幕空间光照(SSGI&am…

Transformer详解常见面试问题

文章目录 1. 各模块解决1.1 输入部分1.2 多头注意力(作者使用8个头)1.3 残差和LayerNorm1.4 Decoder部分 2.Transformer经典问题2.1 tranformer为何使用多头注意力机制?2.2 Transformer相比CNN的优缺点2.3 Encoder和decoder的区别&#xff1f…

Spring中RestTemplate用法

系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 RestTemplate 是从…

自编译frida得一些记录

frida编译 这个过程坑肯定很多 但是只要大方向对得,解决掉每个小错误达到目的就ok得 # 就是想自己把frida代码done下来改一改 然后看看git clone gitgithub.com:frida/frida.git git fetch git checkout 14.1.3# 下载node包管理工具 apt install nvm nvm install …

Web Speech API(1)—— SpeechRecognition

Web Speech API 使你能够将语音数据合并到 Web 应用程序中。Web Speech API 有两个部分:SpeechSynthesis 语音合成(文本到语音 TTS)和 SpeechRecognition 语音识别(异步语音识别)。 SpeechRecognition 语音识别通过 S…

axios案例应用

1、Spring概述 Spring 是分层的 Java SE/EE 应用 full-stack 轻量级开源框架,以 IoC(Inverse Of Control: 反转控制)和 AOP(Aspect Oriented Programming:面向切面编程)为内核,提供了展现层 Spring MVC 和持久层。Spring JDBC 以及业务层事务管理等众多…

day16|二叉树的属性

相关题目 ● 104.二叉树的最大深度 559.n叉树的最大深度 ● 111.二叉树的最小深度 ● 222.完全二叉树的节点个数 二叉树的深度与高度 如图, 二叉树的深度表示:任意一个叶子节点到根节点的距离,是从上往下计数的,因此使用前序遍历…

2024年甘肃特岗教师招聘报名流程,速速查收哦!

2024年甘肃特岗教师招聘报名流程,速速查收哦!

python-鸡兔同笼问题:已知鸡和兔的总头数与总脚数。求笼中鸡和兔各几只?

【问题描述】典型的鸡兔同笼问题。 【输入形式】输入总头数和总脚数两个实数:h,f 【输出形式】笼中鸡和兔的个数:x,y 【样例输入】16 40 【样例输出】鸡12只,兔4只 【样例说明】输入输出必须保证格式正确。…

AI大模型探索之路-训练篇25:ChatGLM3微调实战-基于LLaMA-Factory微调改造企业级知识库

系列篇章💥 AI大模型探索之路-训练篇1:大语言模型微调基础认知 AI大模型探索之路-训练篇2:大语言模型预训练基础认知 AI大模型探索之路-训练篇3:大语言模型全景解读 AI大模型探索之路-训练篇4:大语言模型训练数据集概…

CS西电高悦计网课设——校园网设计

校园网设计 一,需求分析 所有主机可以访问外网 主机可以通过域名访问Web服务器 为网络配置静态或者动态路由 图书馆主机通过DHCP自动获取IP参数 为办公楼划分VLAN 为所有设备分配合适的IP地址和子网掩码,IP地址的第二个字节使用学号的后两位。 二…

ESP32 实现获取天气情况

按照小安派AiPi-Eyes天气站思路,在ESP32 S3上实现获取天气情况。 一、在ESP32 S3实现 1、main.c 建立2个TASK void app_main(void) {//lvgl初始化xTaskCreate(guiTask, "guiTask", 1024 * 6, NULL, 5, NULL);//wifi初始化、socket、json处理taskcustom_…

ES6之数值的扩展

1. 数值的扩展 1.1. 二进制和八进制字面量表示:1.2. 数值判断方法: 1.2.1. Number.isFinite() 检查一个值是否为有限的数值。1.2.2. Number.isNaN() 更准确地检测NaN值。1.2.3. 传统的全局方法 isFinite() 和 isNaN() 的区别 1.3. 数值转换方法:1.4. 整数检查与精度: 1.4.1. Nu…

防火墙技术基础篇:解析防火墙的网络隔离机制

防火墙技术基础篇:解析防火墙的网络隔离机制 网络安全在现代社会中扮演着重要的角色,保护网络系统、用户和数据免受未经授权的访问、破坏和窃取。个人、企业和国家都需要加强网络安全意识,采取有效措施保护自身的网络安全。随着网络攻击手段…

【QT八股文】系列之篇章2 | QT的信号与槽机制及通讯流程

【QT八股文】系列之篇章2 | QT的信号与槽机制及通讯流程 前言2. 信号与槽信号与槽机制介绍/本质/原理,什么是Qt信号与槽机制?如何在Qt中使用?信号与槽机制原理,解析流程Qt信号槽的调用流程信号与槽机制的优缺点信号与槽机制需要注…

web自动化之PO模式

PO模式 1、为什么需要PO思想? 首先我们观察和思考一下,目前我们写的作业脚本的问题: 元素定位和操作动 作写到一起了,这就就会用导致一个问题: UI的页面元素比较容易变化的,所以元素定位和脚本操作写到一…

如何将照片从 iPhone 传输到闪存驱动器【无质量损坏】

概括 人们喜欢用 iPhone 拍照,因为照片通常都很漂亮,这都要归功于 iPhone 令人惊叹的技术。但照片更新后会占用更多空间,并且您可能会开始收到没有存储空间的通知。因此,您可以将照片传输到 USB 驱动器,然后从 iPhone…

springboot-阿里羚羊 服务端埋点

官方文档 集成Java SDK 手动引入jar包「quickaplus-log-collector-java-sdk-1.0.1-SNAPSHOT.jar」 <dependency><groupId>com.alibaba.lingyang</groupId><artifactId>quickaplus-log-collector-java-sdk</artifactId><version>1.0.1&l…

应用案例 | 如何实时监测和管理冷链仓库温湿度?

一、项目背景 冷链仓库温湿度管理的重要性在于确保仓库内产品的质量和安全。通过遵循相关法规和标准&#xff0c;满足客户对产品质量的需求&#xff0c;同时实施有效的温湿度管理措施&#xff0c;可以降低成本并提高仓库作业效率。该项目的实施旨在帮助客户保证产品的新鲜度&a…

Java - AbstractQueuedSynchronizer

AQS简介 AQS全称AbstractQueuedSynchronizer&#xff0c;抽象队列同步器&#xff0c;是一个实现同步组件的基础框架。AQS使用一个int类型的成员变量state维护同步状态&#xff0c;通过内置的同步队列&#xff08;CLH锁、FIFO&#xff09;完成线程的排队工作&#xff0c;底层主…