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.

117 lines
4.9 KiB

  1. # Remote Filesystems
  2. Many users ask about compatibility with remote filesystems. This
  3. section is to describe any known issues or quirks when using mergerfs
  4. with common remote filesystems.
  5. Keep in mind that, like with caching, it is **NOT** a good idea to
  6. change the contents of the remote filesystem
  7. [out-of-band](https://en.wikipedia.org/wiki/Out-of-band). Meaning that
  8. you should not change the contents of the underlying filesystems or
  9. mergerfs on the server hosting the remote filesystem. Doing so can
  10. lead to weird behavior, inconsistency, errors, and even data
  11. corruption should multiple programs try to write or read the same data
  12. at the same time. This isn't to say you can't do it or that data
  13. corruption is likely but it _could_ happen. It is better to always use
  14. the remote filesystem. Even on the machine serving it.
  15. ## NFS
  16. [NFS](https://en.wikipedia.org/wiki/Network_File_System) is a common
  17. remote filesystem on Unix/POSIX systems. Due to how NFS works there
  18. are some settings which need to be set in order for mergerfs to work
  19. with it.
  20. It should be noted that NFS and FUSE (the technology mergerfs uses) do
  21. not work perfectly with one another due to certain design choices in
  22. FUSE (and mergerfs.) Due to these issues, it is generally recommended
  23. to use SMB when possible. That said mergerfs should generally work as
  24. an export of NFS and issues discovered should still be reported.
  25. To ensure compatibility between mergerfs and NFS use the following
  26. settings.
  27. mergerfs settings:
  28. * `noforget`
  29. * `inodecalc=path-hash`
  30. NFS export settings:
  31. * `fsid=UUID`
  32. * `no_root_squash`
  33. `noforget` is needed because NFS uses the `name_to_handle_at` and
  34. `open_by_handle_at` functions which allow a program to keep a
  35. reference to a file without technically having it open in the typical
  36. sense. The problem is that FUSE has no way to know that NFS has a
  37. handle that it will later use to open the file again. As a result, it
  38. is possible for the kernel to tell mergerfs to forget about the node
  39. and should NFS ever ask for that node's details in the future it would
  40. have nothing to respond with. Keeping nodes around forever is not
  41. ideal but at the moment the only way to manage the situation.
  42. `inodecalc=path-hash` is needed because NFS is sensitive to
  43. out-of-band changes. FUSE doesn't care if a file's inode value changes
  44. but NFS, being stateful, does. So if you used the default inode
  45. calculation algorithm then it is possible that if you changed a file
  46. or updated a directory the file mergerfs will use will be on a
  47. different branch and therefore the inode would change. This isn't an
  48. ideal solution and others are being considered but it works for most
  49. situations.
  50. `fsid=UUID` is needed because FUSE filesystems don't have different
  51. `st_dev` values which can cause issues when exporting. The easiest
  52. thing to do is set each mergerfs export `fsid` to some random
  53. value. An easy way to generate a random value is to use the command
  54. line tool `uuid` or `uuidgen` or through a website such as
  55. [uuidgenerator.net](https://www.uuidgenerator.net/).
  56. `no_root_squash` is not strictly necessary but can lead to confusing
  57. permission and ownership issues if root squashing is enabled. mergerfs
  58. needs to run certain commands as `root` and if root squash is enabled
  59. it NFS will tell mergerfs a non-root user is making certain calls.
  60. ## SMB / CIFS
  61. [SMB](https://en.wikipedia.org/wiki/Server_Message_Block) is a
  62. protocol most used by Microsoft Windows systems to share file shares,
  63. printers, etc. However, due to the popularity of Windows, it is also
  64. supported on many other platforms including Linux. The most popular
  65. way of supporting SMB on Linux is via the software Samba.
  66. [Samba](<https://en.wikipedia.org/wiki/Samba_(software)>), and other
  67. ways of serving Linux filesystems, via SMB should work fine with
  68. mergerfs. The services do not tend to use the same technologies which
  69. NFS uses and therefore don't have the same issues. There should not be
  70. special settings required to use mergerfs with Samba. However,
  71. [CIFSD](https://en.wikipedia.org/wiki/CIFSD) and other programs have
  72. not been extensively tested. If you use mergerfs with CIFSD or other
  73. SMB servers please submit your experiences so these docs can be
  74. updated.
  75. ## SSHFS
  76. [SSHFS](https://en.wikipedia.org/wiki/SSHFS) is a FUSE filesystem
  77. leveraging SSH as the connection and transport layer. While often
  78. simpler to setup when compared to NFS or Samba the performance can be
  79. lacking and the project is very much in maintenance mode.
  80. There are no known issues using sshfs with mergerfs. You may want to
  81. use the following arguments to improve performance but your millage
  82. may vary.
  83. - `-o Ciphers=arcfour`
  84. - `-o Compression=no`
  85. More info can be found
  86. [here](https://ideatrash.net/2016/08/odds-and-ends-optimizing-sshfs-moving.html).
  87. ## Other
  88. There are other remote filesystems but none popularly used to serve
  89. mergerfs. If you use something not listed above feel free to reach out
  90. and I will add it to the list.