Linux系统下设置mysql备份数据库定时任务 - 亲自尝试可用

一、检查服务是否安装

在Linux系统下设置计划定时任务,我们使用的是crond服务,首先检查是否安装了crond服务,出现以下情况表示已安装

如未安装,执行安装

yum install -y cronie crontabs

crond 服务的开启与关闭

systemctl start crond 服务开启
systemctl stop crond 服务关闭
systemctl restart crond 服务重启
systemctl status crond 服务状态

二、写备份脚本

使用 vi  /var/spool/cron/mysqlbackup.sh 

因为cron安装在var/spool/cron这里,我就将脚本创建在这,mysqlback.sh你可以随意起名,然后回车会进入这个脚本文件的编辑页面,如下图

Linux系统下设置mysql备份数据库定时任务 - 亲自尝试可用_第1张图片

以上是截图,如需要直接复制,请从下面复制

#!/bin/bash
# Name:mysqlbackup.sh
# This is a ShellScript For Auto DB Backup and Delete old Backup
backupdir=/mnt/mysqlbackup
time=`date +%Y%m%d%H`
/usr/local/mysql/bin/mysqldump -uroot -proot shop > $backupdir/shop_$time.sql
find $backupdir -name "shop_*.sql" -type f -mtime +60 -exec rm {} \;>/dev/null 2>&1

/usr/local/mysql/bin/mysqldump 这个是我的MySQL路径是这里,指定MySQL的bin里的mysqldump程序来执行,backupdir是sql备份文件的文件夹-uroot就是数据库用户是root   然后-proot就是数据库密码是root然后shop是数据库名,后面$都是引用前面声明,$time.sql这是创建sql文件,find就是找文件  $backupdir后面必须要有/  不然找不到 然后-name这些就找文件名了-mtime +60是每隔60天删除一次,我们等下测试每分钟备份一次所以要删除3分钟之前的文件,所以用-mmin +3。

三、给脚本添加执行权限

使用chmod 执行 chmod +x /var/spool/cron/mysqlbackup.sh  前面chmod +x不要动,后面是脚本文件的绝对路径。

四、增加定时任务

修改  vi /etc/crontab,就是添加定时任务来定时执行脚本文件,如下

SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root

# For details see man 4 crontabs

# Example of job definition:
# .---------------- minute (0 - 59)
# |  .------------- hour (0 - 23)
# |  |  .---------- day of month (1 - 31)
# |  |  |  .------- month (1 - 12) OR jan,feb,mar,apr ...
# |  |  |  |  .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |  |  |  |  |
# *  *  *  *  * user-name  command to be executed

#mysqlbuckup
0 3 * * * root  /var/spool/cron/mysqlbackup.sh

前面0是分钟 3 是时钟  ***不用管  root是执行用户。因为等下要测试,每分钟执行脚本文件是

** * * * root /var/spool/cron/mysqlbackup.sh  就是5个*

五、测试定时任务是否可行

1、重启crond服务

Linux系统下设置mysql备份数据库定时任务 - 亲自尝试可用_第2张图片

2、去备份的目录/mnt/mysqlbackup去查看是否生成备份sql文件,测试如果成功,注意修改好定时任务文件crontab,设置你想要的定时记录

 

备注:如果没有生成相应的sql文件

     1、注意检查备份文件mysqlbackup.sh是否正确,提示:注意反复检查。

     2、检查定时任务是否开启,定时任务文件crontab是否正确,一般linux版本不同可能定时的格式内容也不一样

 

你可能感兴趣的:(linux,mysq,定时任务,备份,Mysql,Linux)