borg-import-tar.1 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  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 "BORG-IMPORT-TAR" "1" "2025-05-22" "" "borg backup tool"
  31. .SH NAME
  32. borg-import-tar \- Create a backup archive from a tarball
  33. .SH SYNOPSIS
  34. .sp
  35. borg [common options] import\-tar [options] NAME TARFILE
  36. .SH DESCRIPTION
  37. .sp
  38. This command creates a backup archive from a tarball.
  39. .sp
  40. When giving \(aq\-\(aq as path, Borg will read a tar stream from standard input.
  41. .sp
  42. By default (\-\-tar\-filter=auto) Borg will detect whether the file is compressed
  43. based on its file extension and pipe the file through an appropriate filter:
  44. .INDENT 0.0
  45. .IP \(bu 2
  46. \&.tar.gz or .tgz: gzip \-d
  47. .IP \(bu 2
  48. \&.tar.bz2 or .tbz: bzip2 \-d
  49. .IP \(bu 2
  50. \&.tar.xz or .txz: xz \-d
  51. .IP \(bu 2
  52. \&.tar.zstd or .tar.zst: zstd \-d
  53. .IP \(bu 2
  54. \&.tar.lz4: lz4 \-d
  55. .UNINDENT
  56. .sp
  57. Alternatively, a \-\-tar\-filter program may be explicitly specified. It should
  58. read compressed data from stdin and output an uncompressed tar stream on
  59. stdout.
  60. .sp
  61. Most documentation of borg create applies. Note that this command does not
  62. support excluding files.
  63. .sp
  64. A \fB\-\-sparse\fP option (as found in borg create) is not supported.
  65. .sp
  66. About tar formats and metadata conservation or loss, please see \fBborg export\-tar\fP\&.
  67. .sp
  68. import\-tar reads these tar formats:
  69. .INDENT 0.0
  70. .IP \(bu 2
  71. BORG: borg specific (PAX\-based)
  72. .IP \(bu 2
  73. PAX: POSIX.1\-2001
  74. .IP \(bu 2
  75. GNU: GNU tar
  76. .IP \(bu 2
  77. POSIX.1\-1988 (ustar)
  78. .IP \(bu 2
  79. UNIX V7 tar
  80. .IP \(bu 2
  81. SunOS tar with extended attributes
  82. .UNINDENT
  83. .sp
  84. To import multiple tarballs into a single archive, they can be simply
  85. concatenated (e.g. using \(dqcat\(dq) into a single file, and imported with an
  86. \fB\-\-ignore\-zeros\fP option to skip through the stop markers between them.
  87. .SH OPTIONS
  88. .sp
  89. See \fIborg\-common(1)\fP for common options of Borg commands.
  90. .SS arguments
  91. .INDENT 0.0
  92. .TP
  93. .B NAME
  94. specify the archive name
  95. .TP
  96. .B TARFILE
  97. input tar file. \(dq\-\(dq to read from stdin instead.
  98. .UNINDENT
  99. .SS options
  100. .INDENT 0.0
  101. .TP
  102. .B \-\-tar\-filter
  103. filter program to pipe data through
  104. .TP
  105. .B \-s\fP,\fB \-\-stats
  106. print statistics for the created archive
  107. .TP
  108. .B \-\-list
  109. output verbose list of items (files, dirs, ...)
  110. .TP
  111. .BI \-\-filter \ STATUSCHARS
  112. only display items with the given status characters
  113. .TP
  114. .B \-\-json
  115. output stats as JSON (implies \-\-stats)
  116. .TP
  117. .B \-\-ignore\-zeros
  118. ignore zero\-filled blocks in the input tarball
  119. .UNINDENT
  120. .SS Archive options
  121. .INDENT 0.0
  122. .TP
  123. .BI \-\-comment \ COMMENT
  124. add a comment text to the archive
  125. .TP
  126. .BI \-\-timestamp \ TIMESTAMP
  127. manually specify the archive creation date/time (yyyy\-mm\-ddThh:mm:ss[(+|\-)HH:MM] format, (+|\-)HH:MM is the UTC offset, default: local time zone). Alternatively, give a reference file/directory.
  128. .TP
  129. .BI \-\-chunker\-params \ PARAMS
  130. specify the chunker parameters (ALGO, CHUNK_MIN_EXP, CHUNK_MAX_EXP, HASH_MASK_BITS, HASH_WINDOW_SIZE). default: buzhash,19,23,21,4095
  131. .TP
  132. .BI \-C \ COMPRESSION\fR,\fB \ \-\-compression \ COMPRESSION
  133. select compression algorithm, see the output of the \(dqborg help compression\(dq command for details.
  134. .UNINDENT
  135. .SH EXAMPLES
  136. .INDENT 0.0
  137. .INDENT 3.5
  138. .sp
  139. .EX
  140. # export as uncompressed tar
  141. $ borg export\-tar Monday Monday.tar
  142. # import an uncompressed tar
  143. $ borg import\-tar Monday Monday.tar
  144. # exclude some file types, compress using gzip
  145. $ borg export\-tar Monday Monday.tar.gz \-\-exclude \(aq*.so\(aq
  146. # use higher compression level with gzip
  147. $ borg export\-tar \-\-tar\-filter=\(dqgzip \-9\(dq Monday Monday.tar.gz
  148. # copy an archive from repoA to repoB
  149. $ borg \-r repoA export\-tar \-\-tar\-format=BORG archive \- | borg \-r repoB import\-tar archive \-
  150. # export a tar, but instead of storing it on disk, upload it to remote site using curl
  151. $ borg export\-tar Monday \- | curl \-\-data\-binary @\- https://somewhere/to/POST
  152. # remote extraction via \(dqtarpipe\(dq
  153. $ borg export\-tar Monday \- | ssh somewhere \(dqcd extracted; tar x\(dq
  154. .EE
  155. .UNINDENT
  156. .UNINDENT
  157. .SS Archives transfer script
  158. .sp
  159. Outputs a script that copies all archives from repo1 to repo2:
  160. .INDENT 0.0
  161. .INDENT 3.5
  162. .sp
  163. .EX
  164. for N I T in \(gaborg list \-\-format=\(aq{archive} {id} {time:%Y\-%m\-%dT%H:%M:%S}{NL}\(aq\(ga
  165. do
  166. echo \(dqborg \-r repo1 export\-tar \-\-tar\-format=BORG aid:$I \- | borg \-r repo2 import\-tar \-\-timestamp=$T $N \-\(dq
  167. done
  168. .EE
  169. .UNINDENT
  170. .UNINDENT
  171. .sp
  172. Kept:
  173. .INDENT 0.0
  174. .IP \(bu 2
  175. archive name, archive timestamp
  176. .IP \(bu 2
  177. archive contents (all items with metadata and data)
  178. .UNINDENT
  179. .sp
  180. Lost:
  181. .INDENT 0.0
  182. .IP \(bu 2
  183. some archive metadata (like the original commandline, execution time, etc.)
  184. .UNINDENT
  185. .sp
  186. Please note:
  187. .INDENT 0.0
  188. .IP \(bu 2
  189. all data goes over that pipe, again and again for every archive
  190. .IP \(bu 2
  191. the pipe is dumb, there is no data or transfer time reduction there due to deduplication
  192. .IP \(bu 2
  193. maybe add compression
  194. .IP \(bu 2
  195. pipe over ssh for remote transfer
  196. .IP \(bu 2
  197. no special sparse file support
  198. .UNINDENT
  199. .SH SEE ALSO
  200. .sp
  201. \fIborg\-common(1)\fP
  202. .SH AUTHOR
  203. The Borg Collective
  204. .\" Generated by docutils manpage writer.
  205. .