BORG-IMPORT-TAR(1) | borg backup tool | BORG-IMPORT-TAR(1) |
borg-import-tar - Create a backup archive from a tarball
borg [common options] import-tar [options] NAME TARFILE
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:
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:
See borg-common(1) for common options of Borg commands.
# 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"
Outputs a script that copies all archives from repo1 to repo2:
for A T in `borg list --format='{archive} {time:%Y-%m-%dT%H:%M:%S}{NL}'` do
echo "borg -r repo1 export-tar --tar-format=BORG $A - | borg -r repo2 import-tar --timestamp=$T $A -" done
Kept:
Lost:
Please note:
The Borg Collective
2023-03-01 |