我有一个schedule.rb
文件,每晚运行数据库备份。代码如下:
every :day, :at => '10:20pm' do
fname = Time.now.strftime('%d_%m_%Y_dump.sql')
command "pg_dump -f #{fname}"
command "gzip #{fname}"
end
但是,文件没有更新,根据我的cron日志:
gzip:29_12_2015_dump.sql.gz已经存在;没有被覆盖
gzip:29_12_2015_dump.sql.gz已经存在;没有被覆盖
日志文件最近更新于1月8日。这意味着Time.now
每次运行时都是相同的,即每天。这似乎不太可能,可能会发生什么?
答案 0 :(得分:0)
我意识到问题所在:whenever
将其schedule.rb
文件写入crontab一次,因此文件中的ruby代码仅在该点评估,而不是每次运行作业时。因此"时间戳"具有等于写入crontab的日期的静态值。