$ 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-block
或virtio-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 网站上有一些很好的宣传,其中提到
- 的一些限制
virtio-blk
virtio-scsi
可以在 SCSI LUN 的直通模式下使用,并且可以使用各种新的 SCSI 命令功能,而无需在virtio-scsi
.如果您不是专门使用 SCSI 直通,那么任何新命令都需要 QEMU 中的新支持,但不需要代virtio-scsi
码中的支持。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>