从源PC上一次性p2v(qcow2)的构想

2023-12-25 10:28

本文主要是介绍从源PC上一次性p2v(qcow2)的构想,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

磁盘分区表,虚拟硬盘文件,操作系统引导

1. 基本概念和术语

源硬盘:一般就是客户的PC机的硬盘,硬盘里面包含了Windows分区。

源Windows:以源硬盘启动的Windows环境。

虚拟磁盘文件:文件格式有qcow2、vhd、vhdx等。一个虚拟磁盘文件模拟一个磁盘,要模拟两个磁盘得用两个虚拟磁盘文件。

分区表:常见就mbr和gpt两种。

分区(磁盘分区):给磁盘建立分区表后,可将一个磁盘的存储空间分成若干段落,每一段就是一个分区。

分区表表头:在给磁盘建立分区表后,磁盘初始位置的几百~几千字节的数据就是分区表表头,它索引了该磁盘分为几个分区,每个分区的头尾位置、大小、预设功能等。

gpt备份:磁盘若选用gpt分区表,则磁盘尾部的几百字节数据,它是gpt备份。

磁盘签名、磁盘guid:mbr的分区表表头里有一段数据是磁盘签名,gpt的分区表表头里有一段数据是磁盘guid。它们的诞生时机是新建分区表的时候。windows系统假定每个磁盘的磁盘签名(或磁盘guid)都不同。若两个磁盘的签名(或guid)相同,windows可能会把两个磁盘给弄混了。

引导方式:从bios程序寻找操作系统引导文件的方法,常见的就legacy和uefi两种。可以有mbr配legacy,mbr配uefi,mbr配双引导,gpt配uefi四种。

引导分区:存放系统引导文件的分区。一般是legacy场景下的活动分区和uefi场景下的EFI分区。

引导修复:创建(或找到)引导分区和Windows分区,建立正确的引导文件。

disk2vhd:微软出品的物理磁盘转vhd(x)的工具。

diskgenius:某公司出品的磁盘(分区)综合管理工具。

2. 1.x方案的p2v方案简述

2.1 流程

步骤A所在的环境为源Windows。步骤B(含)之后的操作所在环境简称为转换环境。转换环境一般选用源Windows即可,也可选其它机。

A. 在源Windows里执行disk2vhd,将C盘所在硬盘转为vhd(x)文件。

B. 用Windows自己的磁盘管理器,把vhd(x)像真实磁盘一样挂载到Windows环境里。

C. 根据云桌面对引导方式的需求,要求操作员手工执行mbr(gpt)转gpt(mbr)或自动执行mbr转gpt。

D. 用Windows自己的dism等工具把虚拟化设备的驱动(viosscsi、netkvm等)安装到vhd里的Windows。

E. 用Windows自己的diskpart工具,压缩分区,定制引导分区。

F. 用Windows自己的bcdboot工具修复引导。

G. 用qemu的qemu-img将vhd(x)转为qcow2。

H. 把qcow2所代表的磁盘的尾部的未分配空间砍减掉。

I. 就地启动qemu虚机,以qcow2文件作为磁盘,验证能否启动windows。

K. 上传qcow2到rcdc。

2.2 方案选型考虑

A. 为什么要mbr(gpt)转gpt(mbr)?

正规的配置方案是mbr配legacy,gpt配uefi。rcdc和idv启动镜像前,选取哪种引导方式就跟操作系统和分区表有关。假使源pc是Win10的mbr+legacy,所以我们得到的vhd也是Win10的mbr,但预期rcdc会以uefi启动这个镜像,所以要修正为gpt+uefi。

B. 为什么要经过vhd而不是直接从物理磁盘转为qcow2?

因为vhd能够很容易地像真实磁盘一样挂载出来,只要是挂载出来的磁盘,就能很容易用windows自有工具达成2.1的D、E、F的需求。

若想要qcow2像真实磁盘一样挂载出来,那么有方法但确实不如vhd那么容易。

C. 为什么要把qcow2尾部未分配空间砍减?

假设源硬盘(总量301GB)的分区布局如下:

分区表表头

引导分区(500MB)

D盘(160G)

C盘(30G)

恢复分区(500MB)

E盘(110G)

在disk2vhd运行时,尽管只转换C盘,但是得到的vhd依然是代表301GB的磁盘,分区空间也是划分好的,得到vhd如下布局:

分区表表头

引导分区(500MB)

raw文件系统分区(160G)

C盘(30G)

恢复分区(500MB)

raw文件系统分区(110G)

末尾的110.5GB空间都可以砍减的。如果不砍减,那么rcdc也不支持以301GB的qcow2来新建镜像。

纵使编辑镜像环境没有300GB的限制,如果不砍减,在IDV场景下,即使客户实际只需30G的C盘,那么110.5GB的空间shine模块总要预留出来给C盘扩展用,这个预留就是浪费了的。

3. 旧方案的缺陷

A. vhd文件的生成耗时也不灵活

C盘通常是大几十G,所以生成的vhd也有大几十G,大几十G的文件的生成总要十来分钟。若不经过vhd,直接从物理磁盘到qcow2,这十来分钟就能省下来。

见2.2.C。vhd会把分区表表头,分布布局,磁盘签名(或guid)都从源硬盘复制到vhd里。此时若在源Windows里就地挂载vhd,就会触发相同磁盘签名(或guid)的异常,进而导致转换环境蓝屏,mbr(gpt)转gpt(mbr)异常,引导修复异常等问题。

见2.2.C,vhd里中间160G的未分区部分,C盘不能利用上。这段空间可以新建D盘,但C盘的扩展方向只能往C盘的尾部方向扩展,不能往头部方向扩展。

B. mbr(gpt)转gpt(mbr)麻烦,还会经常失败

失败原因见A。

mbr转gpt可以用windows原生自带的mbr2gpt.exe。但gpt转mbr则需要操作员用diskgenius手工操作,显得操作不够流畅。

C. 砍减qcow2会砍减掉gpt备份

多数情况下没有问题。但是毕竟就使用了不正规的gpt分区形式,有隐患。

D. n个磁盘里的m个分区不能整合到一个qcow2里

n个磁盘就会生成n个vhd。1.x方案没法将n个vhd整合成一个qcow2。

4. 精进方案的构想

4.1 流程

A. 展示源硬盘

例如源硬盘有2个,p2v工具的ui直接展示出来:

分区表表头

引导分区(500MB)

D盘(160G)

C盘(30G)

恢复分区(500MB)

E盘(110G)

分区表表头

F盘(100G)

G盘(50G)

B. 勾选分区

用户在UI上勾选了若干分区,并要求组装成如下形式:

分区表表头

引导分区(500MB)

恢复分区(500MB)

F盘(100G)

D盘(160G)

C盘(30G)

C. 新建qcow2

p2v工具用qemu工具直接新建291G的qcow2。

D. 挂载qcow2

用TCI产品的rjvdisk的技术,把qcow2像物理磁盘一样挂载到Windows的磁盘管理器里。

E. 给qcow2磁盘新建分区表

如B样式划分分区位置和大小。

F. 分区拷贝

直接读取源磁盘各个分区的裸数据,拷贝到qcow2磁盘对应的分区位置里。

G. 其它流程

执行2.1的D、E、F、I、K。

4.2 新方案改良点

A. 跳过大几十G的vhd文件的生成

B. 天然规避了磁盘签名(guid)的雷同

由于4.1.E是新建的分区表,所以磁盘的mbr签名或者gpt的磁盘guid都是新建的,大概率不会跟源磁盘雷同。

C. 不需mbr转gpt或gpt转mbr

D. 镜像分区灵活

可以达成n个磁盘里的m个分区能整合到一个qcow2里。

可以保证C盘的末尾一定是磁盘的末尾,这样C盘就会有充分的扩展空间。

不会出现C盘前头存在未分配空间的情况。

5. 关于精进方案的初步的可行性验证

5.1 把qcow2像物理磁盘一样挂载

TCI产品的vdisk.sys程序就是在Windows开机的早期阶段,模拟一个achi磁盘控制器,再把qcow2当作真实磁盘一样挂载在磁盘控制器下,然后从这个磁盘启动Windows。本文方案在Windows启动之后再模拟一个achi磁盘控制器,再把qcow2挂载和卸载,应该是容易达成的,技术上充分具备的。

5.2 直接读取源磁盘各个分区的裸数据,拷贝到qcow2磁盘对应的分区位置里

直接读写磁盘某某段落的裸数据,p2v1.0已达成。

识别出某个分区的空间是从磁盘头偏移X字节到Y字节,那需要能解析并理解分区表。我也充分清楚了解。

这篇关于从源PC上一次性p2v(qcow2)的构想的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/535173

相关文章

游戏高度可配置化(一)通用数据引擎(data-e)及其在模块化游戏开发中的应用构想图解

游戏高度可配置化(一)通用数据引擎(data-e)及其在模块化游戏开发中的应用构想图解 码客 卢益贵 ygluu 关键词:游戏策划 可配置化 模块化配置 数据引擎 条件系统 红点系统 一、前言 在插件式模块化软件开发当中,既要模块高度独立(解耦)又要共享模块数据,最好的方法是有个中间平台(中间件)提供标准的接口来进行数据的交换,这在很多行业软件开发中已经广泛应用。但是,由于中间件的抽象和封

程序员为什么不能一次性写好,需要一直改Bug?

程序员在编写代码时不能一次性写好,而是需要不断修改Bug,这主要是由几个因素导致的: 复杂性:软件开发是一个高度复杂的过程,涉及到多个模块、功能、逻辑和数据的交互。即使是最有经验的程序员,也很难一次性预见并处理所有可能出现的问题。需求变更:在软件开发过程中,客户需求经常会发生变化。这些变更可能导致已经编写好的代码需要调整,从而引入新的Bug。技术更新:随着技术的不断发展,新的编程语言、框架和库不

前端vite+vue3——利用环境变量和路由区分h5、pc模块打包(从0到1)

⭐前言 大家好,我是yma16,本文分享 前端vite+vue3——利用环境变量和路由对前端区分h5和pc模块打包(从0到1)。 背景: 前端本地开发pc和h5的项目,发布时需要区分开h5和pc的页面 vite Vite 通过在一开始将应用中的模块区分为 依赖 和 源码 两类,改进了开发服务器启动时间。 依赖 大多为在开发时不会变动的纯 JavaScript。一些较大的依赖(

移动端+PC端应用模式的智慧城管综合执法办案平台源码,案件在线办理、当事人信用管理、文书电子送达、沿街店铺分析

城市管理综合执法管理平台实现执法办案、业务全流程在线办理,依托移动端+PC端的“两端”应用模式,保障能够通过信息化手段进行日常的执法办案工作,强化执法监督功能。提供了案件在线办理、当事人信用管理、文书电子送达、沿街店铺分析等功能,全面赋能执法队员,提高执法队员办案效率。 技术框架: 前端框架:vue+element 后端框架:springboot 数 据 库:mysql5.7 移

几种pc端页面 常用的js兼容ie写法,几个名词 nodeName nodeValue及value addEventListener attachEvent

注意这里说的兼容ie浏览器,是说兼容ie8及以前的浏览器。ie9及以后就靠谱多了 function(event){    event=event ||window.event;  //window.event是为了兼容ie } ---------------------------------------- function(event){    event=event ||win

白杨SEO:中国搜索引擎市场份额排名如何,百度还是PC和移动端均第一吗?

前言:这是白杨SEO公众号原创第536篇。为什么分享这个?因为我们不管是做搜索流量还是推荐流量,都应该随时了解当下流量主要在哪,欢迎评论,转发,收藏。图片在公众号白杨SEO优化教程上去看。 文章大纲: 1、2024最新国内搜索引擎排名 2、国内搜索引擎排名变化启发 3、2024全世界搜索引擎排名 4、国内APP活跃用户排名 5、我们为什么要关注这些排名数据? 2024最新国内搜索引擎

AI绘画Stable Diffusion神级插件AnimateDiff超稳动画教程来了!手把手教你一次性学会

大家好,我是设计师阿威 今天给大家分享AI做稳定动画的新教程,这一次的稳定效果,比上一次和上上次都更加惊艳,而且实现难度直线下降!几乎可以说是有手就会,非常适合追求高效高质效果的商用场景! 重点是:更简单!更高效! 今天我们就来用标题中的SD插件AnimateDiff做一个动画视频,AnimateDiff插件下载请扫描获取哦 AnimateDiff在SD的webUI中使用起来,那是非

《JS实现复制内容到剪贴板功能,可兼容所有PC浏览器,不兼容手机端》

前记:本来原生的JS是有提供一个函数来实现这个功能(window.clipboardData),但是很遗憾,这个函数仅仅支持IE和FF浏览器,所以基本用处不大。下边介绍的是一个第三方插件库(ZeroClipboard.js)。   ZeroClipboard.js在Git上的地址为:https://github.com/zeroclipboard/zeroclipboard 注意:此js库不

推荐4款PC端黑科技工具,快来看看,建议收藏

Thunderbird Thunderbird 是由 Mozilla 基金会开发的一款免费且开源的电子邮件客户端,支持 Windows、macOS、Linux 等多种操作系统。它不仅可以用于发送和接收电子邮件,还可以作为新闻阅读器、聊天工具以及日历应用。 Thunderbird 提供了丰富的功能,包括对 IMAP 和 POP3 协议的支持,使用户能够从不同的电子邮件提供商处检索邮件,并使用

智慧工地系统源码,支持项目级、公司级、集团级多级权限划分,支持PC端、手机端

智慧工地的核心是数字化,它通过传感器、监控设备、智能终端等技术手段,实现对工地各个环节的实时数据采集和传输,如环境温度、湿度、噪音等数据信息,将数据汇集到云端进行处理和分析,生成各种报表、图表和预警信息,帮助管理人员了解工地的实时状况,及时做出决策和调整,保证施工作业的顺利进行。同时,智慧工地还可以通过人工智能和大数据技术,对工地数据进行深度分析和挖掘,发现潜在问题和规律,提出优化建议和预测预警,