有 SVN 和 Git 的 Crontab

有 SVN 和 Git 的 Crontab

我有一些存儲庫,它們都在 SVN 和 Git 中。我的用戶名是 Guyfawkes,在我的主目錄中我有一個資料夾 www,其中包含我的所有儲存庫。在這個目錄中我還有檔案 update.sh:

[guyfawkes@guyfawkes-desktop ~/www]$ cat update.sh
cd /home/guyfawkes/www
cd crm
echo "upd crm"
svn up
echo "update crm completed"
echo "-------"
cd ../crm_sql
echo "upd sql"
svn up
echo "update sql completed"
echo "-------"
cd ../crm_old
echo "upd old"
svn up
echo "update old completed"
echo "-------"
cd ../mysqldiff
echo "upd mysqldiff"
git pull sotmarket master
echo "update mysqlidff completed"
git push origin master
echo "push to github completed"
echo "-------"
cd ../mysql-migration-manager
echo "upd mmmm"
git pull
echo "mmm updated"
cd data
echo "upd data"
git pull
echo "data updated"

我的 crontab 是:

[guyfawkes@guyfawkes-desktop ~/www]$ crontab -l
*/5 * * * * /home/guyfawkes/www/update.sh

所以,它與 svn repos 完美配合,但我在 /var/spool/mail/guyfawkes 中有這些郵件(來自 cron):

X-Cron-Env: <SHELL=/bin/sh>
X-Cron-Env: <HOME=/home/guyfawkes>
X-Cron-Env: <PATH=/usr/bin:/bin>
X-Cron-Env: <LOGNAME=guyfawkes>
X-Cron-Env: <USER=guyfawkes>

upd crm

Fetching external item into 'public/old'
External at revision 32674.

At revision 483.
update crm completed
-------
upd sql
At revision 29.
update sql completed
-------
upd old
At revision 32674.
update old completed
-------
upd mysqldiff
Permission denied (publickey,keyboard-interactive).
fatal: The remote end hung up unexpectedly
update mysqlidff completed
Permission denied (publickey).
fatal: The remote end hung up unexpectedly
push to github completed
-------
upd mmmm
Permission denied (publickey,keyboard-interactive).
fatal: The remote end hung up unexpectedly
mmm updated
upd data
Permission denied (publickey,keyboard-interactive).
fatal: The remote end hung up unexpectedly
data updated

我該如何修復它?

答案1

問題是您正在嘗試從 github 進行更新,這需要 ssh 金鑰。在伺服器上建立一個沒有密碼的專用 ssh 金鑰並將其新增至您的 github 帳戶,或使用 http-readonly uri 更新您的儲存庫:

git pull --mirror https://github.com/account/repository.git

相關內容