我有两个要编写的shell脚本,将通过cron schedule每晚执行。
在我的生产服务器上:
mysqldump -ufoo -pbar --opt --routines db > ~/sqldump/{$todays_date}.sql
ln -s ~/sqldump/{$todays_date}.sql latest.sql
在我的开发服务器上:
scp foo@domain.tld:~/sqldump/latest.sql ~/sqldump
mysql -ufoo -pbar db < latest.sql
我有两个问题:
$todays_date
填写日期?例如,“2010-07-21”答案 0 :(得分:3)
要获取今天的日期,请使用date +%F
:
command > ~/sqldump/$(date +%F).sql
要了解有关日期+
格式可以使用的各种选项的更多信息,请查看日期手册页。
至于等待,我认为你的意思是你不想在你的服务器上运行命令,直到你的prod服务器上的命令完成。最好的想法是让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
答案 1 :(得分:2)
除非你使用“&amp;”在第一步的命令结束时,第二步将自动等待它。