Man page - borg2-import-tar(1)
Packages contains this manual
- borg2-diff(1)
- borg2-break-lock(1)
- borg2-umount(1)
- borg2-mount(1)
- borg2-export-tar(1)
- borg2-key(1)
- borg2-common(1)
- borg2-prune(1)
- borg2-match-archives(1)
- borg2-placeholders(1)
- borg2-check(1)
- borg2-compact(1)
- borg2-delete(1)
- borg2-extract(1)
- borg2-benchmark-crud(1)
- borg2-key-export(1)
- borg2-analyze(1)
- borg2(1)
- borg2-list(1)
- borg2-import-tar(1)
- borg2-repo-delete(1)
- borg2-undelete(1)
- borg2-create(1)
- borg2-patterns(1)
- borgfs2(1)
- borg2-compression(1)
- borgbackup2(1)
- borg2-key-change-passphrase(1)
- borg2-recreate(1)
- borg2-version(1)
- borg2-repo-list(1)
- borg2-tag(1)
- borg2-rename(1)
- borg2-repo-create(1)
- borg2-serve(1)
- borg2-transfer(1)
- borg2-benchmark-cpu(1)
- borg2-benchmark(1)
- borg2-info(1)
- borg2-key-change-location(1)
- borg2-repo-compress(1)
- borg2-with-lock(1)
- borg2-key-import(1)
- borg2-repo-info(1)
- borg2-repo-space(1)
apt-get install borgbackup2
Manual
BORG-IMPORT-TAR
NAMESYNOPSIS
DESCRIPTION
OPTIONS
arguments
options
Archive options
EXAMPLES
Archives transfer script
SEE ALSO
AUTHOR
NAME
borg-import-tar - Create a backup archive from a tarball
SYNOPSIS
borg [common options] import-tar [options] NAME TARFILE
DESCRIPTION
This command creates a backup archive from a tarball.
When giving '-' as path, Borg will read a tar stream from standard input.
By default (--tar-filter=auto) Borg will detect whether the file is compressed based on its file extension and pipe the file through an appropriate filter:
|
• |
.tar.gz or .tgz: gzip -d |
|||
|
• |
.tar.bz2 or .tbz: bzip2 -d |
|||
|
• |
.tar.xz or .txz: xz -d |
|||
|
• |
.tar.zstd or .tar.zst: zstd -d |
|||
|
• |
.tar.lz4: lz4 -d |
Alternatively, a --tar-filter program may be explicitly specified. It should read compressed data from stdin and output an uncompressed tar stream on stdout.
Most documentation of borg create applies. Note that this command does not support excluding files.
A --sparse option (as found in borg create) is not supported.
About tar formats and metadata conservation or loss, please see borg export-tar .
import-tar reads these tar formats:
|
• |
BORG: borg specific (PAX-based) |
|||
|
• |
PAX: POSIX.1-2001 |
|||
|
• |
GNU: GNU tar |
|||
|
• |
POSIX.1-1988 (ustar) |
|||
|
• |
UNIX V7 tar |
|||
|
• |
SunOS tar with extended attributes |
To import multiple tarballs into a single archive, they can be simply concatenated (e.g. using "cat") into a single file, and imported with an --ignore-zeros option to skip through the stop markers between them.
OPTIONS
See borg-common(1) for common options of Borg commands.
arguments
|
NAME |
specify the archive name |
TARFILE
input tar file. "-" to read from stdin instead.
options
--tar-filter
filter program to pipe data through
-s , --stats
print statistics for the created archive
|
--list |
output verbose list of items (files, dirs, ...) |
--filter STATUSCHARS
only display items with the given status characters
|
--json |
output stats as JSON (implies --stats) |
--ignore-zeros
ignore zero-filled blocks in the input tarball
Archive options
--comment COMMENT
add a comment text to the archive
--timestamp TIMESTAMP
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.
--chunker-params PARAMS
specify the chunker parameters (ALGO, CHUNK_MIN_EXP, CHUNK_MAX_EXP, HASH_MASK_BITS, HASH_WINDOW_SIZE). default: buzhash,19,23,21,4095
-C COMPRESSION , --compression COMPRESSION
select compression algorithm, see the output of the "borg help compression" command for details.
EXAMPLES
# export as
uncompressed tar
$ borg export-tar Monday Monday.tar
# import an
uncompressed tar
$ borg import-tar Monday Monday.tar
# exclude some
file types, compress using gzip
$ borg export-tar Monday Monday.tar.gz --exclude '*.so'
# use higher
compression level with gzip
$ borg export-tar --tar-filter="gzip -9" Monday
Monday.tar.gz
# copy an
archive from repoA to repoB
$ borg -r repoA export-tar --tar-format=BORG archive - |
borg -r repoB import-tar archive -
# export a tar,
but instead of storing it on disk, upload it to remote site
using curl
$ borg export-tar Monday - | curl --data-binary @-
https://somewhere/to/POST
# remote
extraction via "tarpipe"
$ borg export-tar Monday - | ssh somewhere "cd
extracted; tar x"
Archives transfer script
Outputs a script that copies all archives from repo1 to repo2:
for N I T in
`borg list --format='{archive} {id}
{time:%Y-%m-%dT%H:%M:%S}{NL}'`
do
echo "borg -r repo1 export-tar --tar-format=BORG aid:$I
- | borg -r repo2 import-tar --timestamp=$T $N -"
done
Kept:
|
• |
archive name, archive timestamp |
|||
|
• |
archive contents (all items with metadata and data) |
Lost:
|
• |
some archive metadata (like the original commandline, execution time, etc.) |
Please note:
|
• |
all data goes over that pipe, again and again for every archive |
||
|
• |
the pipe is dumb, there is no data or transfer time reduction there due to deduplication |
||
|
• |
maybe add compression |
||
|
• |
pipe over ssh for remote transfer |
||
|
• |
no special sparse file support |
SEE ALSO
borg-common(1)
AUTHOR
The Borg Collective