使用qemu-nbd挂载qcow2/raw磁盘文件

转自:
https://blog.sharpbai.com/2022/02/%e4%bd%bf%e7%94%a8qemu-nbd%e6%8c%82%e8%bd%bdqcow2-raw%e7%a3%81%e7%9b%98%e6%96%87%e4%bb%b6/

问题
使用kvm构建虚拟机系统时,会遇到操作qcow2或raw块设备文件的需求。之前我一直是将其挂载到一个现成的linux系统虚拟机上进行操作,有没有直接在宿主机上操作的方法呢?

方法
最近发现qemu提供了一个很有用的工具qemu-nbd,可以将包括qcow2格式及raw格式的文件进行直接挂载。

下面进行一下演示,创建一个1GB的qcow2文件,挂载到块设备,分区并格式化。

首先创建一个空磁盘文件

qemu-img create -f qcow2 test-sda-1G.qcow2 1G

接下来加载nbd的内核扩展

modprobe nbd max_part=8

此时可以观察到,/dev/下生成了十几个nbd开头的设备,这些都是可以用于挂载块设备文件的挂载点。

我们将刚刚生成的test-sda-1G.qcow2挂载到nbd0上

qemu-nbd --connect=/dev/nbd0 test-sda-1G.qcow2

此时qcow2文件已经成为了一个标准的块设备/dev/nbd0,可以通过fdisk -l /dev/nbd0来列出其信息

我们使用fdisk对/dev/nbd0进行分区操作,创建两个分区并保存,结果如下

# fdisk -l /dev/nbd0
Disk /dev/nbd0: 1 GiB, 1073741824 bytes, 2097152 sectors
Units: sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disklabel type: dos
Disk identifier: 0x8ff00943
 
Device      Boot  Start     End Sectors  Size Id Type
/dev/nbd0p1 *      2048  411647  409600  200M 83 Linux
/dev/nbd0p2      411648 2097151 1685504  823M 83 Linux

接下来我们可以对分区进行格式化操作


mkfs.ext2 /dev/nbd0p1
mkfs.ext4 /dev/nbd0p2

此时文件系统创建完成,已经可以进行挂载了

此时可以挂载并进行操作,完成后我们可以断开设备连接

qemu-nbd -d /dev/nbd0

此时qcow2文件脱离nbd0块设备,已经就绪可以用于虚拟机内使用了

相关推荐

  1. 使用qemu-nbd挂载qcow2/raw磁盘文件

    2023-12-08 12:40:05       43 阅读
  2. CentOS 磁盘挂载

    2023-12-08 12:40:05       10 阅读
  3. Linux 新磁盘挂载

    2023-12-08 12:40:05       6 阅读
  4. ubuntu 永久 磁盘挂载

    2023-12-08 12:40:05       5 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-08 12:40:05       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-08 12:40:05       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-08 12:40:05       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-08 12:40:05       18 阅读

热门阅读

  1. CentOS 7.9安装zabbix5.0.39LTS版本

    2023-12-08 12:40:05       28 阅读
  2. 力扣labuladong——一刷day68

    2023-12-08 12:40:05       37 阅读
  3. Python:核心知识点整理大全7-笔记

    2023-12-08 12:40:05       31 阅读
  4. Flask中redis的配置与使用

    2023-12-08 12:40:05       36 阅读
  5. 1-Hadoop原理与技术

    2023-12-08 12:40:05       32 阅读
  6. Pytorch当中transpose()和permute()函数的区别

    2023-12-08 12:40:05       38 阅读
  7. 最新PyTorch机器学习与深度学习实践技术应用

    2023-12-08 12:40:05       39 阅读
  8. InterLM代码解析

    2023-12-08 12:40:05       33 阅读
  9. 处理合并目录下的Excel文件数据并指定列去重

    2023-12-08 12:40:05       39 阅读
  10. Next.js 中的中间件

    2023-12-08 12:40:05       28 阅读
  11. [C#]文件的读写-1

    2023-12-08 12:40:05       37 阅读