あるシステムから別のシステムに読み書きするためにルートが必要なファイルをコピーしたいと思います。私の現在の解決策は、各システムでsudoを使用し、示されているようにteeを使用することです。
ssh host sudo cat /etc/somefile | sudo tee /etc/somefile > /dev/null
tee
これは機能しますが、teeは入力をstdoutに送信するため、出力を/ dev / nullに送信する必要があります。
cat
UNIXとコピーコマンドを見ましたが、cp
答えが見つかりませんでした。
バラよりhttps://man7.org/linux/man-pages/man1/cp.1.html
そしてhttps://man7.org/linux/man-pages/man1/cat.1.html
sudo
更新:今、このソリューションにはサポートが必要なので、単純な使用ソリューションは機能しないことを明示する必要cat
があることに気づきました。
例えば、
ssh host sudo cat /etc/somefile | sudo cat > /etc/somefile
ディレクトリ/etc
はルート(私の場合)のみを書き込むことができ、ファイルリダイレクトは> /etc/somefile
現在のユーザー(/ etcに書き込む権限がないユーザー)で実行されるため失敗します。
ベストアンサー1
持っている:
sh -c 'exec cat > file'
または、すべての$file
sに対して環境変数として渡されます。
sudo FILE="$file" sh -c 'exec cat > "$FILE"'
またはパラメータとして:
sudo sh -c 'exec cat > "$1"' sh "$file"
(sh
入るインラインスクリプトの内容$0
)$file
$1
(以下で開く>>
代わりに参照してください。>
追加モードまたは1<>
切り捨てなしで(そして読み取り+書き込みモードで)開いてファイルを所定の位置に上書きします(dd
's conv=notrunc
)。
とにかくいいえする:
sudo sh -c "cat>$file 実行"
$file
シェル構文に特殊文字(スペースなど;
)を含めると失敗し、$
コマンドインジェクションの脆弱性が発生するためです。
さらに:
dd bs=65536 of=file
(転送レポートを抑制するためにstatus=none
GNUと互換性があるか実装されていますdd
。ファイルを開く方法を制御するための多くのオプションがあり、そのリストは実装によって異なりますdd
。)
ほとんどのシステムでは:
cp /dev/stdin file
moreutils
もっとある
sponge file
sort
少なくともGNUを使用し、テキスト入力時:
sort -mo file
テキスト入力(またはsed
テキスト以外のものを処理できる実装)を使用してください。
sed -n 'w file'
テキスト入力を使用する:
awk '{print > "file"}'
またはGNUを使用してくださいawk
:
gawk -v ORS= '{print $0 RT > "file"}'
ssh
ここからルートとしてローカルファイルを開き、通常のユーザーとして実行することもできます。
sudo zsh -c '
USERNAME=$SUDO_USER ssh host 'sudo cat /etc/somefile' > /etc/somefile'
これは、データが追加のパイプを通過する必要がないことを意味します。
また、すぐに圧縮を使用xz
し、pixz
ファイルへの解凍サポートを使用してローカルに解凍することもできます。
ssh host 'sudo xz -0 -c /etc/somefile' | sudo pixz -tdo /etc/somefile