passthrough
- default: off
- arguments:- off: Passthrough is never enabled.
- ro: Only enable passthrough when file opened for reading only.
- wo: Only enable passthrough when file opened for writing only.
- rw: Enable passthrough when file opened for reading, writing, or both.
 
In Linux 6.9
a IO passthrough feature was added to FUSE. Typically mergerfs has
to act as an active proxy for all read and write requests. This
results in, at times, significant overhead compared to direct
interaction with the underlying filesystems. Not because mergerfs is
doing anything particularly slow but because the additional
communication and data transfers required. With the passthrough
feature mergerfs is able to instruct the kernel to perform reads and
writes directly on the underlying file. Bypassing mergerfs entirely
(specifically and only for reads and writes) and thereby providing
near native performance.
This performance does come at the cost of some functionality as
mergerfs no longer has control over reads and writes which means all
features related to read/write are affected.
- moveonenospc: Does not work because errors are
  not reported back to mergerfs.
- nullrw: Since mergerfsno longer receives read/write requests there is no read or write to ignore.
- readahead: Still affects the readaheadvalues of underlying filesystems andmergerfsitself but no longer relevant tomergerfsin that it is not servicing IO requests.
- fuse_msg_size: The primary reason to increase
  the FUSE message size is to allow transferring more data per request
  which helps improve read and write performance. Without read/write
  requests being sent to mergerfsthere is little reason to have larger message sizes since the only other message larger than 1 page, directory reading, currently has a small fixed buffer size.
- parallel-direct-writes: Not only is direct-ioandpassthroughmutually exclusive but sincemergerfsno longer receives write requests in passthrough mode then there is no parallel writes possible.
- cache.writeback: FUSE's writeback caching is
  incompatible with passthrough. Ifcache.writeback=truewhen enablingpassthroughit will be reset tofalse.
- cache.files: Must be enabled for passthroughto work. Whencache.files=offFUSE'sdirect-iomode is enabled which overridespassthrough.Meaningcache.filesshould be set topartial,fullorauto-fullto usepassthrough. Ifcache.filesis set tooffwhen usingpassthroughit will reset it toauto-full.
Technically mergerfs has the ability to choose options like
passthrough, direct-io, and page caching independently for every
file opened. However, at the moment there is no use case for picking
and choosing which to enable outside cache.files=per-process (which
is largely unnecessary on Linux v6.6 and above. See
direct-io-allow-mmap) If such a use case arises please
reach out to the author to discuss.
Unlike preload.so, passthrough will work for
any software interacting with mergerfs. However, passthrough
requires Linux v6.9 or above to work.
NOTE: This feature will ONLY work if mergerfs is running as
root as currently only root is allowed to leverage the kernel
feature.
NOTE: If a file has been opened and passthrough enabled, while that
file is open, if another open request is made mergerfs must also
enable passthrough for the second open request. This is a limitation
of how the passthrough feature works.
Alternatives
- preload.so: Leverages the ability to
  intercept certain filesystem calls to bypass mergerfsfor IO. See page for details and limitations.
Benchmarks
Simple dd based benchmark on a Hades Canyon (Intel i7-8809G, 32GB
DDR4-2400 RAM).
# /mnt/test is mergerfs over a single tmpfs mount
dd if=/dev/zero of=/mnt/test/tmpfile bs=1M count=2000 oflag=nocache
conv=fdatasync status=progress
Summary: passthrough is ~95% native speed. 200% faster than
direct-io (cache.files=off).
- straight to tmpfs: 1.7 GB/s
- nullrw=true: 2.1 GB/s
- cache.files=off; passthrough=off: 800 MB/s
- cache.files=auto-full; passthrough=rw: 1.6 GB/s
- cache.files=auto-full; cache.writeback=false: 518 MB/s
- cache.files=auto-full; cache.writeback=true: 518 MB/s