borgfs.1 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. .\" Man page generated from reStructuredText.
  2. .
  3. .
  4. .nr rst2man-indent-level 0
  5. .
  6. .de1 rstReportMargin
  7. \\$1 \\n[an-margin]
  8. level \\n[rst2man-indent-level]
  9. level margin: \\n[rst2man-indent\\n[rst2man-indent-level]]
  10. -
  11. \\n[rst2man-indent0]
  12. \\n[rst2man-indent1]
  13. \\n[rst2man-indent2]
  14. ..
  15. .de1 INDENT
  16. .\" .rstReportMargin pre:
  17. . RS \\$1
  18. . nr rst2man-indent\\n[rst2man-indent-level] \\n[an-margin]
  19. . nr rst2man-indent-level +1
  20. .\" .rstReportMargin post:
  21. ..
  22. .de UNINDENT
  23. . RE
  24. .\" indent \\n[an-margin]
  25. .\" old: \\n[rst2man-indent\\n[rst2man-indent-level]]
  26. .nr rst2man-indent-level -1
  27. .\" new: \\n[rst2man-indent\\n[rst2man-indent-level]]
  28. .in \\n[rst2man-indent\\n[rst2man-indent-level]]u
  29. ..
  30. .TH "BORGFS" "1" "2025-04-18" "" "borg backup tool"
  31. .SH NAME
  32. borgfs \- Mount archive or an entire repository as a FUSE filesystem
  33. .SH SYNOPSIS
  34. .sp
  35. borgfs [options] REPOSITORY_OR_ARCHIVE MOUNTPOINT [PATH...]
  36. .SH DESCRIPTION
  37. .sp
  38. This command mounts a repository or an archive as a FUSE filesystem.
  39. This can be useful for browsing or restoring individual files.
  40. .sp
  41. When restoring, take into account that the current FUSE implementation does
  42. not support special fs flags and ACLs.
  43. .sp
  44. When mounting a repository, the top directories will be named like the
  45. archives and the directory structure below these will be loaded on\-demand from
  46. the repository when entering these directories, so expect some delay.
  47. .sp
  48. Unless the \fB\-\-foreground\fP option is given the command will run in the
  49. background until the filesystem is \fBumounted\fP\&.
  50. .sp
  51. Performance tips:
  52. .INDENT 0.0
  53. .IP \(bu 2
  54. when doing a \(dqwhole repository\(dq mount:
  55. do not enter archive dirs if not needed, this avoids on\-demand loading.
  56. .IP \(bu 2
  57. only mount a specific archive, not the whole repository.
  58. .IP \(bu 2
  59. only mount specific paths in a specific archive, not the complete archive.
  60. .UNINDENT
  61. .sp
  62. The command \fBborgfs\fP provides a wrapper for \fBborg mount\fP\&. This can also be
  63. used in fstab entries:
  64. \fB/path/to/repo /mnt/point fuse.borgfs defaults,noauto 0 0\fP
  65. .sp
  66. To allow a regular user to use fstab entries, add the \fBuser\fP option:
  67. \fB/path/to/repo /mnt/point fuse.borgfs defaults,noauto,user 0 0\fP
  68. .sp
  69. For FUSE configuration and mount options, see the mount.fuse(8) manual page.
  70. .sp
  71. Borg\(aqs default behavior is to use the archived user and group names of each
  72. file and map them to the system\(aqs respective user and group ids.
  73. Alternatively, using \fBnumeric\-ids\fP will instead use the archived user and
  74. group ids without any mapping.
  75. .sp
  76. The \fBuid\fP and \fBgid\fP mount options (implemented by Borg) can be used to
  77. override the user and group ids of all files (i.e., \fBborg mount \-o
  78. uid=1000,gid=1000\fP).
  79. .sp
  80. The man page references \fBuser_id\fP and \fBgroup_id\fP mount options
  81. (implemented by fuse) which specify the user and group id of the mount owner
  82. (aka, the user who does the mounting). It is set automatically by libfuse (or
  83. the filesystem if libfuse is not used). However, you should not specify these
  84. manually. Unlike the \fBuid\fP and \fBgid\fP mount options which affect all files,
  85. \fBuser_id\fP and \fBgroup_id\fP affect the user and group id of the mounted
  86. (base) directory.
  87. .sp
  88. Additional mount options supported by borg:
  89. .INDENT 0.0
  90. .IP \(bu 2
  91. \fBversions\fP: when used with a repository mount, this gives a merged, versioned
  92. view of the files in the archives. EXPERIMENTAL, layout may change in future.
  93. .IP \(bu 2
  94. \fBallow_damaged_files\fP: by default damaged files (where missing chunks were
  95. replaced with runs of zeros by \fBborg check \-\-repair\fP) are not readable and
  96. return EIO (I/O error). Set this option to read such files.
  97. .IP \(bu 2
  98. \fBignore_permissions\fP: for security reasons the \fBdefault_permissions\fP mount
  99. option is internally enforced by borg. \fBignore_permissions\fP can be given to
  100. not enforce \fBdefault_permissions\fP\&.
  101. .UNINDENT
  102. .sp
  103. The BORG_MOUNT_DATA_CACHE_ENTRIES environment variable is meant for advanced users
  104. to tweak the performance. It sets the number of cached data chunks; additional
  105. memory usage can be up to ~8 MiB times this number. The default is the number
  106. of CPU cores.
  107. .sp
  108. When the daemonized process receives a signal or crashes, it does not unmount.
  109. Unmounting in these cases could cause an active rsync or similar process
  110. to unintentionally delete data.
  111. .sp
  112. When running in the foreground, ^C/SIGINT cleanly unmounts the filesystem,
  113. but other signals or crashes do not.
  114. .SH OPTIONS
  115. .sp
  116. See \fIborg\-common(1)\fP for common options of Borg commands.
  117. .SS arguments
  118. .INDENT 0.0
  119. .TP
  120. .B REPOSITORY_OR_ARCHIVE
  121. repository or archive to mount
  122. .TP
  123. .B MOUNTPOINT
  124. where to mount filesystem
  125. .TP
  126. .B PATH
  127. paths to extract; patterns are supported
  128. .UNINDENT
  129. .SS options
  130. .INDENT 0.0
  131. .TP
  132. .B \-V\fP,\fB \-\-version
  133. show version number and exit
  134. .TP
  135. .B \-\-consider\-checkpoints
  136. Show checkpoint archives in the repository contents list (default: hidden).
  137. .TP
  138. .B \-f\fP,\fB \-\-foreground
  139. stay in foreground, do not daemonize
  140. .TP
  141. .B \-o
  142. Extra mount options
  143. .TP
  144. .B \-\-numeric\-owner
  145. deprecated, use \fB\-\-numeric\-ids\fP instead
  146. .TP
  147. .B \-\-numeric\-ids
  148. use numeric user and group identifiers from archive(s)
  149. .UNINDENT
  150. .SS Archive filters
  151. .INDENT 0.0
  152. .TP
  153. .BI \-P \ PREFIX\fR,\fB \ \-\-prefix \ PREFIX
  154. only consider archive names starting with this prefix. (deprecated)
  155. .TP
  156. .BI \-a \ GLOB\fR,\fB \ \-\-glob\-archives \ GLOB
  157. only consider archive names matching the glob. sh: rules apply (without actually using the sh: prefix), see \(dqborg help patterns\(dq.
  158. .TP
  159. .BI \-\-sort\-by \ KEYS
  160. Comma\-separated list of sorting keys; valid keys are: timestamp, archive, name, id; default is: timestamp
  161. .TP
  162. .BI \-\-first \ N
  163. consider first N archives after other filters were applied
  164. .TP
  165. .BI \-\-last \ N
  166. consider last N archives after other filters were applied
  167. .UNINDENT
  168. .SS Include/Exclude options
  169. .INDENT 0.0
  170. .TP
  171. .BI \-e \ PATTERN\fR,\fB \ \-\-exclude \ PATTERN
  172. exclude paths matching PATTERN
  173. .TP
  174. .BI \-\-exclude\-from \ EXCLUDEFILE
  175. read exclude patterns from EXCLUDEFILE, one per line
  176. .TP
  177. .BI \-\-pattern \ PATTERN
  178. include/exclude paths matching PATTERN
  179. .TP
  180. .BI \-\-patterns\-from \ PATTERNFILE
  181. read include/exclude patterns from PATTERNFILE, one per line
  182. .TP
  183. .BI \-\-strip\-components \ NUMBER
  184. Remove the specified number of leading path elements. Paths with fewer elements will be silently skipped.
  185. .UNINDENT
  186. .SH SEE ALSO
  187. .sp
  188. \fIborg\-common(1)\fP
  189. .SH AUTHOR
  190. The Borg Collective
  191. .\" Generated by docutils manpage writer.
  192. .