我有两个shell脚本要编写,它们将通过cron调度每晚执行。
生产服务器上的:
mysqldump -ufoo -pbar --opt --routines db > ~/sqldump/{$todays_date}.sqlln -s ~/sqldump/{$todays_date}.sql latest.sql我的开发服务器上的:
scp foo@domain.tld:~/sqldump/latest.sql ~/sqldumpmysql -ufoo -pbar db < latest.sql我有两个问题:
$todays_date填写日期?例如,"2010-07-21"发布于 2010-07-21 19:14:59
要获取今天的日期,请使用date +%F
command > ~/sqldump/$(date +%F).sql若要了解有关日期的+格式可以使用的各种选项的更多信息,请查看日期手册页。
至于等待,我想您的意思是,在prod服务器上的命令完成之前,您不希望在dev服务器上运行该命令。最好的方法是让dev服务器使用ssh (即ssh user@host "mysqldump ... > ... && ln -s ...)启动命令。
如果您不想这样做,我认为最好的方法是使用临时文件,以便转储文件的创建是原子的:
mysqldump ... > ~/sqldump/tmp$$ && mv ~/sqldump/tmp$$ ~/sqldump/$(date +%F).sql然后,如果您的dev服务器请求是今天日期的转储,那么您可以循环直到scp成功:
while ! scp foo@domain.tld:~/sqldump/$(date +%F).sql ~/sqldump; do
# file not present yet, sleep 1 minute and try again
sleep 60
done
mysql -ufoo -pbar db < latest.sql发布于 2010-07-21 19:17:23
除非在第一步的命令末尾使用"&“,否则第二步将自动等待。
https://stackoverflow.com/questions/3302891
复制相似问题