Istnieje wiele sposobów robienia tego, co chcesz. Najprostszym jest użycie pìpe:
tar zcvf - MyBackups | ssh user@server "cat > /path/to/backup/foo.tgz"
Tutaj obsługiwana jest kompresja, za pomocą tar
której wywołań gzip
( z
flaga). Możesz także użyć compress
( Z
) i bzip
( j
). Na 7z
to zrobić:
tar cf - MyBackups | 7za a -si -mx=9 -ms=on MyBackups.tar.7z |
ssh user@server "cat > /path/to/backup/foo.7z"
Najlepszym sposobem jest jednak pewnie rsync
.
Rsync is a fast and extraordinarily versatile file copying tool. It can copy
locally, to/from another host over any remote shell, or to/from a remote rsync dae‐
mon. It offers a large number of options that control every aspect of its behavior
and permit very flexible specification of the set of files to be copied. It is
famous for its delta-transfer algorithm, which reduces the amount of data sent over
the network by sending only the differences between the source files and the exist‐
ing files in the destination. Rsync is widely used for backups and mirroring and
as an improved copy command for everyday use.
rsync
ma sposób zbyt wiele opcji. Naprawdę warto je przeczytać, ale są przerażające od pierwszego wejrzenia. Tymi, na których Ci zależy w tym kontekście, są:
-z, --compress compress file data during the transfer
--compress-level=NUM explicitly set compression level
-z, --compress
With this option, rsync compresses the file data as it is sent to the desti‐
nation machine, which reduces the amount of data being transmitted --
something that is useful over a slow connection.
Note that this option typically achieves better compression ratios than can
be achieved by using a compressing remote shell or a compressing transport
because it takes advantage of the implicit information in the matching data
blocks that are not explicitly sent over the connection.
W twoim przypadku chciałbyś czegoś takiego:
rsync -z MyBackups user@server:/path/to/backup/
Pliki zostaną skompresowane podczas transportu i zostaną zdekompresowane do miejsca docelowego.
Więcej opcji do wyboru:
scp
sam może kompresować dane
-C Compression enable. Passes the -C flag to ssh(1) to
enable compression.
$ scp -C source user@server:/path/to/backup
Może być sposób na uzyskanie rsync
i 7za
dobrą zabawę, ale nie ma sensu tego robić. Zaletą rsync
jest to, że kopiuje tylko te bity, które zmieniły się między plikami lokalnymi i zdalnymi. Jednak niewielka lokalna zmiana może spowodować bardzo inny skompresowany plik, więc nie ma sensu tego używać rsync
. To tylko komplikuje sprawy bez korzyści. Po prostu użyj bezpośredniego, ssh
jak pokazano powyżej. Jeśli naprawdę chcesz to zrobić, możesz spróbować, podając podpowłokę jako argument rsync
. W moim systemie nie mogłem tego uruchomić, 7za
ponieważ nie pozwala ci to na zapisywanie skompresowanych danych na terminalu. Być może Twoja implementacja jest inna. Spróbuj czegoś takiego ( to nie działa dla mnie ):
rsync $(tar cf - MyBackups | 7za a -an -txz -si -so) \
user@server:/path/to/backup
Inną kwestią jest to, że 7z
nie należy jej używać do tworzenia kopii zapasowych w systemie Linux . Jak podano na 7z
stronie podręcznika :
NIE UŻYWAJ formatu 7-zip do tworzenia kopii zapasowych w systemie Linux / Unix, ponieważ:
- 7-zip nie przechowuje właściciela / grupy pliku.
-z
jest co najmniej dwa razy wolniejszy. Aby uzyskać jeszcze większą prędkość niż rsyncing przez ssh, skonfiguruj demona rsync i rsync za pomocą-W
flagi (kopiuje pliki w całości (bez algorytmu delta-xfer).