compress_bz2_block_size_100k
Default | [None] |
---|---|
Value | unsigned integer |
The compression block size to use. Must be between 1
(100 000
bytes)
and 9
(900 000
bytes).
mail-compress
) This plugin can be used to read compressed mbox, maildir or dbox files. It can also be used to write (via IMAP, LDA and/or LMTP Server) compressed messages to dbox or Maildir mailboxes.
The following algorithms are supported:
Name | Library (algorithm) | Dovecot Support |
---|---|---|
bz2 | libbzip2 (bzip2) | v2.0+ |
gz | zlib (gzip) | v2.0+ |
deflate | zlib (gzip) | v2.0+ |
lz4 | liblz4 | v2.2.11+ |
zstd | Zstandard | v2.3.12+ |
compress_bz2_block_size_100k
Default | [None] |
---|---|
Value | unsigned integer |
The compression block size to use. Must be between 1
(100 000
bytes)
and 9
(900 000
bytes).
compress_deflate_level
Default | [None] |
---|---|
Value | unsigned integer |
The compression level to use for deflate compression. Must be between 0
(no compression) and 9
.
compress_gz_level
Default | [None] |
---|---|
Value | unsigned integer |
The compression level to use for gz compression. Must be between 0
(no compression) and 9
.
compress_zstd_level
Default | [None] |
---|---|
Value | unsigned integer |
The compression level to use for zstd compression. Must be between 1
and
22
.
mail_compress_write_method
Default | [None] |
---|---|
Value | string |
The Compression Method to use for writing new mails. If empty, new mails are written without compression. Old mails can still be read.
# Enable compression plugin globally for reading/writing:
mail_plugins {
mail_compress = yes
}
# Enable compressing the mails while saving (not just reading):
mail_compress_write_method = zstd
Compressed mbox files can be accessed only as read-only. The compression is detected based on the file name, so your compressed mboxes should end with .gz or .bz2 extension. There is no support for compression during saving.
Mails can be stored as compressed. Existing uncompressed mails can't currently be directly compressed (or vice versa).
You could, however, use doveadm-sync(1)
to copy all mails to another location (which saves them compressed) and then replace the original location with the new compressed location. You can do this by treating the operation the same as if you were migrating from one mailbox format to another (see the dsync page examples).
When this plugin is loaded Dovecot can read both compressed and uncompressed files from Maildir. The files within a Maildir can use any supported compression algorithm (e.g., some can be compressed using gzip, while others are compressed using zstd). The algorithm is detected by reading the first few bytes from the file and figuring out if it's a valid compressed header. The file name doesn't matter.
To avoid IMAP clients attempting to exploit security holes in the compression algorithm libraries (e.g., bzlib) by writing specially crafted mails using IMAP's APPEND command, Dovecot will not allow clients to save mails that are detected as compressed.
All mails must have ,S=<size>
in their filename where <size> contains the original uncompressed mail size, otherwise there will be problems with quota calculation as well as other potential random failures. Note that if the filename doesn't contain the ,S=<size>
before compression, adding it afterwards changes the base filename and thus the message UID. The safest thing to do is simply to not compress such files.
You should also preserve the file's mtime so INTERNALDATE doesn't change.
If you want to use dsync to convert to a compressed Maildir you may need -o
maildir_copy_with_hardlinks=no
(this is set to yes by default and will prevent compression).
To compress existing mails, the supported way is to use local dsync migration. See migrating mailboxes.
You'll probably want to use some cronjob to compress old mails. However note that to avoid seeing duplicate mails in rare race conditions you'll have to use the maildirlock utility. The idea is to:
Find the mails you want to compress in a single maildir.
,S=<size>
in the filename.Compress the mails to tmp/
Run maildirlock <path> <timeout>
. It writes PID to stdout, save it.
<path>
is path to the directory containing Maildir's dovecot-uidlist (the control directory, if it's separate)<timeout>
specifies how long to wait for the lock before failing.If maildirlock grabbed the lock successfully (exit code 0) you can continue.
For each mail you compressed:
rename() (mv)
the compressed file over the original file.Dovecot can now read the file, but to avoid compressing it again on the next run, you'll probably want to rename it again to include e.g. a Z
flag in the file name to mark that it was compressed (e.g. 1223212411.M907959P17184.host,S=3271:2,SZ
).
Remember that the Maildir specifications require that the flags are sorted by their ASCII value, although Dovecot itself doesn't care about that.
Unlock the maildir by sending a TERM signal to the maildirlock process (killing the PID it wrote to stdout).