总结:Linux系统上面定时备份mysql指定数据库的解决方案

  • 一·Mysql数据库本身就自带备份数据库命令
    • 1.mysql本身自带备份数据库为一个sql文件的命令,只需要在操作系统的终端里面执行就好了
  • 二·Linux和Unix操作系统都自带一个定时任务执行器:crontab
    • 1.一些基本的crontab命令示例:
    • 2.如何用crontab -e命令添加一个定时任务:
  • 三·将crontab定时任务与mysql的备份命令结合起来,形成最终解决方案
    • 1.先将mysql的备份命令写成脚本文件形式(mysql-backup.sh)
    • 2.给脚本文件授权(可执行权限)
    • 3.使用 crontab 命令设置定时任务:
  • 四·常见异常:MySQL备份脚本写入Crontab计划性任务之后生成的备份文件大小为0解决方法

一·Mysql数据库本身就自带备份数据库命令

1.mysql本身自带备份数据库为一个sql文件的命令,只需要在操作系统的终端里面执行就好了

命令格式1:mysqldump -h [IP或域名] -P [端口号] -u [登录账号] -p[登录密码] --databases [数据库名称] > [最终生成sql文件的存储路径]/xxx.sql示例:mysqldump-h localhost -P 3306 -u root -p123456 --databases test > /Users/ideal/Desktop/test.sql命令格式2:不从配置文件读取对应参数值,必须命令行给出值mysqldump --no-defaults-h [IP或域名] -P [端口号] -u [登录账号] -p[登录密码] --databases [数据库名称] > [最终生成sql文件的存储路径]/xxx.sql示例:mysqldump --no-defaults-h localhost -P 3306 -u root -p123456 --databases test > /Users/ideal/Desktop/test.sql

注意:-p后面必须紧跟密码,之间不能有空格,不然会有问题

二·Linux和Unix操作系统都自带一个定时任务执行器:crontab

在Linux系统中,有一个非常强大的定时任务执行器,它叫做crontab。 crontab可以让用户在固定的时间、日期或者周期性地执行某些任务或命令。 crontab的使用非常简单,用户只需要编辑自己的crontab文件,就可以添加、修改或删除自己的定时任务。

1.一些基本的crontab命令示例:

crontab -l :列出当前用户的所有定时任务。
crontab -e :编辑当前用户的定时任务。
crontab -r :删除当前用户的所有定时任务。
crontab -u user -l :列出指定用户的所有定时任务。
crontab -u user -e :编辑指定用户的定时任务。
crontab -u user -r :删除指定用户的所有定时任务。

2.如何用crontab -e命令添加一个定时任务:

(1)使用crontab -e命令编辑或创建一个用户的计划任务列表。

crontab -e

(2)在计划任务列表中,每一行就代表一个计划任务。语法格式如下

* * * * * command arg1 arg2| | | | || | | | ----- Day of the Week (0 - 7) (Sunday is both 0 and 7)| | | ------- Month (1 - 12)| | --------- Day of the Month (1 - 31)| ----------- Hour (0 - 23)------------- Minute (0 - 59)

注意:这计划任务列表里面的command命令,其实就是Linux操作系统里面的命令。但有些命令是需要依赖系统环境变量的,而定时任务执行器里面却并不一定能够访问系统环境变量。所以建议使用命令的绝对路径。

例如:

0 2 * * * /path/to/your/script.sh

(3)添加完之后,可以使用crontab -l命令查看添加结果

三·将crontab定时任务与mysql的备份命令结合起来,形成最终解决方案

1.先将mysql的备份命令写成脚本文件形式(mysql-backup.sh)

(1)mysql-backup.sh脚本文件内容如下所示:自定义信息需要自己完善

#!/bin/bash# MySQL Server 登录信息MYUSER="数据库用户名"MYPASS="数据库用户密码"MYHOST="数据库主机地址"MYPORT="数据库端口号,默认为3306"MYDB="需要备份的数据库名称"# 备份相关配置信息BAKDIR="/var/db-backup/$(date +'%Y-%m-%d')"# 备份保存目录BAKFILE="$BAKDIR/db.$(date +'%Y-%m-%d-%H%M%S').sql.gz"# 备份文件名KEEPDAYS=7# 保留天数# 创建备份目录if [ ! -d "$BAKDIR" ]; thenmkdir -p "$BAKDIR"fi# 备份数据库至压缩文件mysqldump -h "$MYHOST" -P "$MYPORT" -u "$MYUSER" -p"$MYPASS" --databases "$MYDB" | gzip > "$BAKFILE"# 清理旧备份文件,只保留指定天数内的备份,超过时间的就会被清除find "$BAKDIR" -name '*.sql.gz' -type f -mtime +"$KEEPDAYS" -delete

2.给脚本文件授权(可执行权限)

chmod 777 mysql-backup.sh

3.使用 crontab 命令设置定时任务:

0 2 * * * /usr/local/bin/mysql-backup.sh

四·常见异常:MySQL备份脚本写入Crontab计划性任务之后生成的备份文件大小为0解决方法

https://cloud.tencent.com/developer/article/1833718