使用crontab定时备份数据库

2020-10-20 20:10:35 Linux 178

简介

我们可能经常面临这一些数据丢失的风险,因此对数据源进行定时备份任务是十分有必要的事情了。在Linux中我们可以快捷的使用crontab这个工具来定时启动我们的任务。Linux内置的cron进程能帮我们实现这些需求,cron搭配shell脚本,非常复杂的指令也没有问题。

crontab介绍

我们经常使用的是crontab命令是cron table的简写,它是cron的配置文件,也可以叫它作业列表,我们可以在以下文件夹内找到相关配置文件。

  • /var/spool/cron/ 目录下存放的是每个用户包括root的crontab任务,每个任务以创建者的名字命名
  • /etc/crontab 这个文件负责调度各种管理和维护任务。
  • /etc/cron.d/ 这个目录用来存放任何要执行的crontab文件或脚本。
  • 我们还可以把脚本放在/etc/cron.hourly/etc/cron.daily/etc/cron.weekly/etc/cron.monthly目录中,让它每小时/天/星期、月执行一次。

 crontab使用

输入下面的命令会创建一个以当前用户运行的新cron任务。

crontab -e

如果你想要以其他用户运行cron任务,输入下面的命令。

sudo crontab -u  -e

根据屏幕提示输入数字1-5中的一个,将会出现下面的文本。

每个cron任务的格式如下。

< 分钟> < 小时> < 日> < 月> < 星期> < 命令>

下图比较清晰明了,转自:命令格式

crontab的命令构成为 时间+动作,其时间有分、时、日、月、周五种,操作符有

  • * 取值范围内的所有数字
  • / 每过多少个数字
  • - 从X到Z
  • 散列数字

举几个栗子

  • 每一分钟执行一次命令
    • * * * * * cd /home/
  • 每天凌晨2点10分钟执行重启命令
    • 10 02 * * * reboot
  • 每隔两天执行一次重启命令
    • * * */2 * * reboot

定时备份数据库文件

有了上述的基础我们就可以自己写一个shell脚本来每天定时备份数据库数据了,shell脚本内容如下。

#!/bin/bash
date_str=$(date "+%Y-%m-%d")
pwd="123"
echo $date_str
cd /home/ubuntu/data-backup
mysqldump -h localhost -u root --password=$pwd -R -E -e \blog> /home/ubuntu/data-backup/$date_str.sql

上面代码就是备份数据库的shell脚本,具体的信息根据个人信息进行更改。

然后我们将其将入到crontab中去,这样我们就可以每天定时备份数据库数据,可以最小减少数据损失。

您尚未登录, 登录注册 后评论

当前共有0条评论