VirtIO 存储是否支持丢弃 (fstrim)?

VirtIO 存储是否支持丢弃 (fstrim)?
$ uname -r
5.0.9-301.fc30.x86_64
$ findmnt /
TARGET SOURCE    FSTYPE OPTIONS
/      /dev/vda3 ext4   rw,relatime,seclabel
$ sudo fstrim -v /
fstrim: /: the discard operation is not supported

相同的虚拟机,但将磁盘从 VirtIO 切换到 SATA 后:

$ findmnt /
TARGET SOURCE    FSTYPE OPTIONS
/      /dev/sda3 ext4   rw,relatime,seclabel
$ sudo fstrim -v /
/: 5.3 GiB (5699264512 bytes) trimmed

虚拟磁盘由 QCOW2 文件支持。我正在使用 virt-manager / libvirt。 libvirt-daemon 版本为 4.7.0-2.fc29.x86_64。我的主机当前运行的是 vanilla 内核版本 5.1(ish),因此目前它有点“定制”,但我是从现有的 Fedora 内核配置开始构建它的。

有没有办法以某种方式启用 VirtIO 上的丢弃支持?或者代码还不支持它?我不一定需要如何启用它的确切说明,但我感到惊讶和好奇,我想要一个可靠的答案:-)。

答案1

显然该设置不支持丢弃。但是,如果将磁盘从“VirtIO”更改为“SCSI”,并将 SCSI 控制器更改为“VirtIO”,则它可以工作。我找到了一个演练。有几个演练;这只是第一个搜索结果。这个新选项称为virtio-scsi.另一个较旧的系统称为virtio-blockvirtio-blk

我还发现了一个很棒的主题Ubuntu 错误跟踪器。它指出virtio-blk在Linux 5.0中开始支持丢弃请求。它说这也需要 QEMU 的支持,该支持于 2019 年 2 月 22 日提交。因此,在未来的版本中,我认为我们将自动获得 VirtIO 和丢弃支持。


目前,我的默认情况下virt-manager不会创建virtio-scsi磁盘,即使它知道我正在安装 Fedora 29;它仅创建基本的“VirtIO”磁盘。不知道切换到virtio-scsi.

我猜想与模拟 SATA 相比,virtio-scsi它提供了与 SATA 相同的性能优势。 virtio-blk(我在 :-P 中的任何地方都没有看到使用 NVME 协议的选项virt-manager,无论是否有 VirtIO)。

oVirt 网站上有一些很好的宣传,其中提到

  1. 的一些限制virtio-blk
  2. virtio-scsi可以在 SCSI LUN 的直通模式下使用,并且可以使用各种新的 SCSI 命令功能,而无需在virtio-scsi.如果您不是专门使用 SCSI 直通,那么任何新命令都需要 QEMU 中的新支持,但不需要代virtio-scsi​​码中的支持。
  3. virtio-scsi包括对多个队列的支持。 (我不清楚这是否也有助于提高单队列硬件的效率)。

答案2

我必须在 libvirt 域 XML 文件中显式启用丢弃才能使其正常工作:

   <devices>
     <disk type='file' device='disk'>
-      <driver name='qemu' type='raw'/>
+      <driver name='qemu' type='raw' discard='unmap'/>
       <source file='...'/>
       <target dev='vda' bus='virtio'/>
       <address type='pci' domain='0x0000' bus='0x04' slot='0x00' function='0x0'/>
     </disk>

答案3

对sourcejedi的答案的一个小补充

为了支持 virtio-blk 中的丢弃,您还需要更新虚拟机配置中的“machine”。

  • 在 pc-q35-3.1 中,virtio-blk 不支持丢弃
  • 在 pc-q35-4.2 中,确实如此

无论如何,最好将虚拟机配置更新到最新的计算机。或者只使用别名“q35”而不指定确切的版本

qemu-system-x86_64 -machine help | grep q35

例如,

<type arch='x86_64' machine='pc-q35-7.2'>hvm</type>

相关内容