gzipで圧縮してリモートサーバーに送信するパスが%pのファイルがいくつかありますが、rsyncや同様のミラーリングツールを使用できないとします。私は次のことを行います。
gzip -c -9 %p | ssh user@server "cat > backupPath"
基本的な通常の状況ではうまくいきますが、ファイル転送中にリモートサーバー接続が失敗した場合は、ファイルが正しく送信され保存されていることを確認したいので、どうなるかを知りたいです。ファイルの一部だけが「backupPath」に書き込まれますか、それとも「全部または専務」戦略に従いますか?つまり、エラーが発生し、「backupPath」アドレスを持つファイルがリモートホストに作成されません(私に適しています)。より良い)?
答え1
プロセスの観点からは、cat
stdinからstdoutにデータをコピーするだけであり、データが完全であるか、特に完全であるかはわかりません。したがって、あなたの質問に対する答えは次のとおりです。いいえこれは「全部または専務」戦略ではありません。
2段階で行うことができ、より強力になります。
#/bin/bash
set -e
set -o pipefail
gzip -c -9 %p | ssh user@server "cat > backupPath.tmp"
ssh user@server "mv backupPath.tmp backupPath"
これは%p
元の投稿からコピーされ、シェル構文ではありません。
答え2
名前変更はアトミックタスクなので、ダウンロードが完了した後にファイル名を変更することはオプションのようです。私が知っているのは、zipの整合性を確認しても、ファイルが完全にダウンロードされたことを保証するものではありません。ファイルの対応する部分が正しいzipファイルである可能性も少なくなります。しかし、とにかくセキュリティを強化するためにdrubenが整合性をチェックするというアイデアは気に入っています。だからIcarusとDrubenの答えのおかげで、私は最終決定を下しました。
gzip -c -9 %p | ssh user@server 'set -e; cat > /var/tmp/file.txt.part; gzip -t /var/tmp/file.txt.part; sync /var/tmp/file.txt.part; mv /var/tmp/file.txt.part /var/tmp/file.txt'