borg-import-tar.1 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. .\" Man page generated from reStructuredText.
  2. .
  3. .TH BORG-IMPORT-TAR 1 "2022-04-14" "" "borg backup tool"
  4. .SH NAME
  5. borg-import-tar \- Create a backup archive from a tarball
  6. .
  7. .nr rst2man-indent-level 0
  8. .
  9. .de1 rstReportMargin
  10. \\$1 \\n[an-margin]
  11. level \\n[rst2man-indent-level]
  12. level margin: \\n[rst2man-indent\\n[rst2man-indent-level]]
  13. -
  14. \\n[rst2man-indent0]
  15. \\n[rst2man-indent1]
  16. \\n[rst2man-indent2]
  17. ..
  18. .de1 INDENT
  19. .\" .rstReportMargin pre:
  20. . RS \\$1
  21. . nr rst2man-indent\\n[rst2man-indent-level] \\n[an-margin]
  22. . nr rst2man-indent-level +1
  23. .\" .rstReportMargin post:
  24. ..
  25. .de UNINDENT
  26. . RE
  27. .\" indent \\n[an-margin]
  28. .\" old: \\n[rst2man-indent\\n[rst2man-indent-level]]
  29. .nr rst2man-indent-level -1
  30. .\" new: \\n[rst2man-indent\\n[rst2man-indent-level]]
  31. .in \\n[rst2man-indent\\n[rst2man-indent-level]]u
  32. ..
  33. .SH SYNOPSIS
  34. .sp
  35. borg [common options] import\-tar [options] ARCHIVE 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: 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. .SH OPTIONS
  84. .sp
  85. See \fIborg\-common(1)\fP for common options of Borg commands.
  86. .SS arguments
  87. .INDENT 0.0
  88. .TP
  89. .B ARCHIVE
  90. name of archive to create (must be also a valid directory name)
  91. .TP
  92. .B TARFILE
  93. input tar file. "\-" to read from stdin instead.
  94. .UNINDENT
  95. .SS optional arguments
  96. .INDENT 0.0
  97. .TP
  98. .B \-\-tar\-filter
  99. filter program to pipe data through
  100. .TP
  101. .B \-s\fP,\fB \-\-stats
  102. print statistics for the created archive
  103. .TP
  104. .B \-\-list
  105. output verbose list of items (files, dirs, ...)
  106. .TP
  107. .BI \-\-filter \ STATUSCHARS
  108. only display items with the given status characters
  109. .TP
  110. .B \-\-json
  111. output stats as JSON (implies \-\-stats)
  112. .UNINDENT
  113. .SS Archive options
  114. .INDENT 0.0
  115. .TP
  116. .BI \-\-comment \ COMMENT
  117. add a comment text to the archive
  118. .TP
  119. .BI \-\-timestamp \ TIMESTAMP
  120. manually specify the archive creation date/time (UTC, yyyy\-mm\-ddThh:mm:ss format). alternatively, give a reference file/directory.
  121. .TP
  122. .BI \-c \ SECONDS\fR,\fB \ \-\-checkpoint\-interval \ SECONDS
  123. write checkpoint every SECONDS seconds (Default: 1800)
  124. .TP
  125. .BI \-\-chunker\-params \ PARAMS
  126. specify the chunker parameters (ALGO, CHUNK_MIN_EXP, CHUNK_MAX_EXP, HASH_MASK_BITS, HASH_WINDOW_SIZE). default: buzhash,19,23,21,4095
  127. .TP
  128. .BI \-C \ COMPRESSION\fR,\fB \ \-\-compression \ COMPRESSION
  129. select compression algorithm, see the output of the "borg help compression" command for details.
  130. .UNINDENT
  131. .SH EXAMPLES
  132. .INDENT 0.0
  133. .INDENT 3.5
  134. .sp
  135. .nf
  136. .ft C
  137. # export as uncompressed tar
  138. $ borg export\-tar /path/to/repo::Monday Monday.tar
  139. # import an uncompressed tar
  140. $ borg import\-tar /path/to/repo::Monday Monday.tar
  141. # exclude some file types, compress using gzip
  142. $ borg export\-tar /path/to/repo::Monday Monday.tar.gz \-\-exclude \(aq*.so\(aq
  143. # use higher compression level with gzip
  144. $ borg export\-tar \-\-tar\-filter="gzip \-9" repo::Monday Monday.tar.gz
  145. # copy an archive from repoA to repoB
  146. $ borg export\-tar \-\-tar\-format=BORG repoA::archive \- | borg import\-tar repoB::archive \-
  147. # export a tar, but instead of storing it on disk, upload it to remote site using curl
  148. $ borg export\-tar /path/to/repo::Monday \- | curl \-\-data\-binary @\- https://somewhere/to/POST
  149. # remote extraction via "tarpipe"
  150. $ borg export\-tar /path/to/repo::Monday \- | ssh somewhere "cd extracted; tar x"
  151. .ft P
  152. .fi
  153. .UNINDENT
  154. .UNINDENT
  155. .SS Archives transfer script
  156. .sp
  157. Outputs a script that copies all archives from repo1 to repo2:
  158. .INDENT 0.0
  159. .INDENT 3.5
  160. .sp
  161. .nf
  162. .ft C
  163. for A T in \(gaborg list \-\-format=\(aq{archive} {time:%Y\-%m\-%dT%H:%M:%S}{LF}\(aq repo1\(ga
  164. do
  165. echo "borg export\-tar \-\-tar\-format=BORG repo1::$A \- | borg import\-tar \-\-timestamp=$T repo2::$A \-"
  166. done
  167. .ft P
  168. .fi
  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. .