【问题标题】:Cron to run every 4 hours with different name then overwrite, MySQL dbCron 每 4 小时运行一次,名称不同,然后覆盖 MySQL db
【发布时间】:2014-01-29 07:42:01
【问题描述】:

我想每隔几个小时运行一次 cron 作业来备份我的 mysql 数据库。

当它运行 24 小时后,我希望它重新启动,然后覆盖每个文件。

我想到的最好的是:

15 0 * * * /usr/bin/mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > /PATH/backup1.sql
15 4 * * * /usr/bin/mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > /PATH/backup2.sql
15 8 * * * /usr/bin/mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > /PATH/backup3.sql
15 12 * * * /usr/bin/mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > /PATH/backup4.sql
15 16 * * * /usr/bin/mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > /PATH/backup5.sql
15 20 * * * /usr/bin/mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > /PATH/backup6.sql

是否有更有效的方法来执行此操作并执行 cron 作业自动覆盖文件,还是我需要添加一个开关?

服务器新手,但必须学习!

【问题讨论】:

标签: mysql unix cron


【解决方案1】:

我会选择类似的东西:

15 */4 * * * /bin/bash /path/to/your/script.sh

这会在第 15 分钟每 4 小时执行一次 /bin/bash /path/to/your/script.sh

然后让script.sh成为:

num=$(( ($(date "+%H") + 4 ) / 4))
/usr/bin/mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > /PATH/backup${num}.sql

得到

hour    num
 0       1
 4       2
 ....
20       6

我用:

  • $(date "+%H") 返回小时。
  • $(date "+%H") + 4 返回小时 +4。
  • $(( ($(date "+%H") + 4 ) / 4)) 返回小时 +4 除以 4。

【讨论】:

    【解决方案2】:

    您可以简单地在实际备份之前轮换备份。

    #!/bin/sh
    
    for I in `jot 5 5 1`; do
      NN=`expr $I + 1`
      mv backup$I.sql backup$NN.sql
    done
    mysqldump -u DBUSERNAME -pDBPASSWORD DBNAME > backup1.sql
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-03-12
      • 1970-01-01
      • 2018-02-18
      • 1970-01-01
      • 2017-05-26
      • 2023-04-06
      相关资源
      最近更新 更多