ZFS Compression

From Lustre Wiki
Revision as of 19:09, 30 April 2015 by Sknolin (talk | contribs)
Jump to navigation Jump to search

Notes on enabling and working with zfs compression

We assume this is for zfs on lustre, but will work the same for standalone zfs. To do this on a lustre/zfs system, you have to perform these commands on every OST in the system. I would definitely not bother doing this on metadata.

'NOTE - here I'll assume you always work on a whole pool or filesystem, but these commands should work on any arbitrary directory too.

<STORAGE> = the pool, filesystem, or directory you choose.

Check ZFS compression

zfs get compression <STORAGE>

Set ZFS compression

zfs set compression=on <STORAGE>

turns on compression with default algorithm (lzjb). You can chose values other than "on" for the compression algorithm, see 'man zfs' for details.

To use a different algorithm, use for example "compression=lz4" instead of "on".

lz4 is likely the best choice now. It has been tested extensively, and provides very good compression balanced with performance. Basically, it stops trying to compress after compressing some initial part of the data and getting poor results. Details from experts on this topic is needed

I think you might only need to set this on pools, and filesystems should inherit, but to be safe, you can apply it to everything.

Check compression ratio

On OSS:

zfs get compressratio <STORAGE>

On client machines: Keep in mind that fastidious users will likely notice their data apparently shrank if they move things around to a compressed filesystem. "du --aparent-size" on some files or directories can help show what is happening.