You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

2.8 KiB

branches-mount-timeout

  • type: UINT (seconds)
  • default: 0

mergerfs is compatible with any path, whether it be a mount point or a directory on your root filesystem. It doesn’t require branch paths to be mounted or to match a specific filesystem at startup, and it operates effectively without needing details about the intended filesystem. This flexibility eliminates the need to manage mount ordering, which is particularly advantageous on modern systems where filesystems are mounted asynchronously, resulting in unpredictable mount sequences. While systemd offers a way to enforce mount dependencies using the x-systemd.requires=PATH option in /etc/fstab, applying this to every branch path is both cumbersome and susceptible to errors.

branches-mount-timeout will cause mergerfs to first attempt to mount each branch if the branch appears to be on the same filesystem as the mergerfs mount point and then wait for all branches to become "mounted." The logic to determine "mounted" is as follows.

  1. It is mounted if the branch directory has the extended attribute user.mergerfs.branch
  2. It is mounted if the branch directory contains a file named .mergerfs.branch
  3. It is not mounted if the branch directory has the extended attribute user.mergerfs.branch_mounts_here
  4. It is not mounted if the branch directory contains a file named .mergerfs.branch_mounts_here
  5. It is mounted if the st_dev value of the mergerfs mount point is different from the branch path.

These files and xattrs are used to help mergerfs know whether or not a directory happens to be a branch or is the underlying directory mount point.

NOTE: If on a systemd based system and using fstab it is a good idea to set the mount option x-systemd.mount-timeout to some value longer than branches-mount-timeout otherwise systemd might kill mergerfs before it finishes waiting.

NOTE: The way mergerfs attempts to mount the branch is by calling out to the system command mount with the branch as the target. If that path is configured in /etc/fstab as a mount point then mount should attempt to mount it with the settings defined in fstab.

branches-mount-timeout-fail

Default: false

When set to true mergerfs will fail entirely after branches-mount-timeout expires without all branches being mounted. If set to false it will simply ignore the mount status of the branches and continue on. The details will be logged.