rsyncコマンドを開始するbackup.shファイルがあります。このrsyncは、Raspbianを実行しているRaspberryPiから専用サーバーをバックアップするためのものです。
(私はキーチェーンを使用しているため、パスワードなどを入力する必要はありません...)
問題は、バッチを手動で起動するとすべてがうまく機能しますが、crontab(同じユーザーを使用)では次のエラーが発生することです。
2013/10/07 19:36:02 [6456] rsync: connection unexpectedly closed (0 bytes received so far) [Receiver]
2013/10/07 19:36:02 [6456] rsync error: error in rsync protocol data stream (code 12) at io.c(605) [Receiver=3.0.9]
これは私のbackup.shファイルです。
#!/bin/bash
echo "_ backup start "$(date +%H:%M:%S)
echo " "
/usr/bin/rsync -avh --rsync-path='/usr/bin/rsync' --delete --log-file='/home/user/rsync.'$(date +%d%m%Y-%H%M%S)'.log' --rsh='ssh -p 1234' [email protected]:/path/to/archives/ /media/backup/
echo " "
echo "_ backup end "$(date +%H:%M:%S)
これでcrontabライン(crontab -e)
# m h dom mon dow command
30 5 * * * /home/user/backup.sh | mail -s "Backup RPi "$(date +\%d/\%m/\%Y-\%X) [email protected]
挨拶
ベストアンサー1
(私はキーチェーンを使用しているため、パスワードなどを入力する必要はありません...)
いいですね。 cronジョブで実行されているプログラムにキーチェーンを見つける方法を教えてください。
SSHは環境変数(キーチェーン偽装)を介してSSHエージェントを見つけますSSH_AUTH_SOCK
。したがって、crontabでこの環境変数を設定する必要があります。
一般的な構成では、ランダムなSSH_AUTH_SOCK
名前を持つソケットへのパスです。キーチェーンを使用しているので、そのソケットの代替名を簡単に見つけることができます。キーチェーンは、~/.keychain
設定SSH_AUTH_SOCK
やその他の類似変数(SSH_AGENT_PID
、、)GPG_AGENT_INFO
の環境変数宣言を含むファイルを作成します。したがって、クローン操作に適切なファイルを含めるだけです。
[email protected]
30 5 * * * . ~/.keychain/$(hostname)-sh; /home/user/backup.sh
(余談:cronにはジョブ出力を含むEメールを送信する機能が組み込まれているため、ジョブが実際に一部の出力を生成した場合にのみEメールを受信できます。操作は不要です| mail
。)