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

sou*_*edi 7 virtio fstrim libvirt

$ 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
Run Code Online (Sandbox Code Playgroud)

相同的 VM,但在将磁盘从 VirtIO 切换到 SATA 之后:

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

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

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

sou*_*edi 8

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

我还在Ubuntu bug tracker上找到了一个很棒的线程。它指出virtio-blk在 Linux 5.0中开始支持丢弃请求。它说这也需要 QEMU 的支持,该支持于 2019 年 2 月 22 日提交。因此,在未来的版本中,我认为我们将自动获得 VirtIO 和丢弃支持。


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

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

oVirt 网站有一些不错的宣传,其中提到

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