Using VDO on Ubuntu

Icon demonstrating compression

Icon showing compression
Pack and dedupe your files automatically!

Unfortunately, this hasn’t gotten as much attention as I think it should, but vdo volumes are now officially supported as in-tree modules in kernel 6.9 and newer. If you don’t know what vdo volumes are yet, check this out (they’re really cool).

In my opinion, vdo is the best alternative to zfs‘s compression and deduplication on Linux, especially since its license is not incompatible, allowing it to receive a lot more support from developers for being released under GPL-2. I’ve been using it off and on for the last few months, and while I haven’t done any formal benchmarks yet, subjectively it seems to be a lot more effective for reducing space consumption than zfs ever was (zfs‘s compression worked great, but dedupe is hampered by unreasonable ram usage).

The kernel 6.9 requirement makes using vdo a little difficult in Ubuntu 24.04, which does have lvm libraries new enough to make vdo volumes, but not without upgrading the kernel to one newer than stock, since it’s pinned at kernel 6.8. Thankfully, you can add kernels from a 3rd-party rather easily, such as zen, liquorix, or xanmod (I have personally done all my testing with xanmod).

With a 6.9 (or newer) kernel booted, all you need besides lvm and thin-provisioning-tools is the userspace modules for maintaing a vdo volume, and those can be downloaded here: https://github.com/dm-vdo/vdo/releases/tag/8.3.0.71

They need to be compiled manually, but luckily it’s really easy. First, install required libraries and autotools, etc.

Bash
apt install -y build-essential uuid-dev libblkid-dev zlib1g-dev

grab the tar from the dm-vdo/vdo releases page and decompress it. Then, navigate to the folder and run:

Bash
make
sudo make install

The prefix is automatically set to /usr, so the executables are in /usr/bin:

Bash
ls -1 /usr/bin | grep vdo                                                                 

vdoaudit
vdodebugmetadata
vdodumpblockmap
vdodumpmetadata
vdoforcerebuild
vdoformat
vdolistmetadata
vdoreadonly
vdorecover
vdostats

With some accompanying man files:

Bash
/usr/man/man8/vdoaudit.8
/usr/man/man8/vdodebugmetadata.8
/usr/man/man8/vdodumpblockmap.8
/usr/man/man8/vdodumpmetadata.8
/usr/man/man8/vdoforcerebuild.8
/usr/man/man8/vdoformat.8
/usr/man/man8/vdolistmetadata.8
/usr/man/man8/vdoreadonly.8
/usr/man/man8/vdorecover.8
/usr/man/man8/vdostats.8

A bash-completion file for vdostats:

Bash
/usr/share/bash-completion/completions/vdostats

And 3 example files written in perl for monitoring space on a vdo volume:

Bash
ls -1 /usr/share/doc/vdo/examples/monitor                  
                                                                                              
monitor_check_vdostats_logicalSpace.pl
monitor_check_vdostats_physicalSpace.pl
monitor_check_vdostats_savingPercent.pl

(you can invoke them with perl /usr/share/doc/vdo/examples/$EXAMPLE_NAME.pl)

If you do any side-by-side benchmarks with vdo v. zfs, please leave a comment and let me know your results. I plan to do my own eventually, but if you get around to them before I do, I’d love to see your results!


2 responses to “Using VDO on Ubuntu”

    • Seems a little terse, but I didn’t include any of the commands to create a volume because they’re all over the net. Maybe this will help: redhat-9-lvm-commands-for-vdo

      Anyone attempting to use a new kernel module has to load the modules before trying to utilize them. So for instance, creating a vdo device with lvm requires sudo modprobe dm_vdo to load the modules (it pulls in a few more along with it), and then the synopsis for the lvm command is: sudo lvcreate --type vdo --name my_vdo_lv --size 100G --virtualsize 1T $VOLGROUP

      I usually create a file in /etc/modules-load.d to make the kernel module load automatically… echo 'dm_vdo' | sudo tee -a /etc/modules-load.d/dm-vdo.conf. I guess this response is long enough I should probably put it in the article…

Leave a Reply

Your email address will not be published. Required fields are marked *