Mysql数据库定时备份脚本分享

 更新时间:2020年09月01日 14:34:20   作者:低调小熊猫  
这篇文章主要分享了Mysql数据库的定时备份脚本,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下

BackUpMysql.sh脚本

#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin
export PATH

#数据库ip
DBHOST=''
#数据库用户名
DBUSER=''
#数据库用密码
DBPASSWD=''
#需要备份的数据库,多个数据库用空格分开
DBNAME=''

#备份时间
backtime=`date +%Y-%m-%d_%H%M%S`
#备份路径(当前目录)
BACKPATH=$(dirname $(readlink -f $0))
echo $BACKPATH
#日志备份路径
LOGPATH="${BACKPATH}/log"
#数据备份路径
DBPATH="${BACKPATH}/db"

#创建备份目录
[ ! -d "${LOGPATH}" ] && mkdir -p "${LOGPATH}"
[ ! -d "${DBPATH}" ] && mkdir -p "${DBPATH}"

#日志记录头部
echo "备份时间为${backtime},备份数据库表 ${DBNAME} 开始" >> ${LOGPATH}/mysqlback.log

#正式备份数据库
for table in $DBNAME; do
source=`mysqldump -u ${DBUSER} -h${DBHOST} -p${DBPASSWD} ${table}> ${LOGPATH}/${backtime}.sql` 2>> ${LOGPATH}/mysqlback.log;

#备份成功以下操作 $?获取上一个命令的操作结果,0代表成功
if [ "$?" == 0 ];then
cd ${LOGPATH}
#为节约硬盘空间,将数据库压缩
tar -czf ${DBPATH}/${table}${backtime}.tar.gz ./${backtime}.sql > /dev/null
#删除原始文件,只留压缩后文件
rm -f ${LOGPATH}/${backtime}.sql
#删除七天前备份,也就是只保存7天内的备份
find $DBPATH -name "*.tar.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
echo "数据库表 ${DBNAME} 备份成功!!" >> ${LOGPATH}/mysqlback.log
else
#备份失败则进行以下操作
echo "数据库表 ${DBNAME} 备份失败!!" >> ${LOGPATH}/mysqlback.log
fi
done

通过 crontab 定时执行 BackUpMysql.sh 脚本,配置每天晚上12点执行

运行 crontab -e

输入

59 23 * * * /data/mysqlbak/BackUpMysql.sh

本文作者: 低调小熊猫
本文链接: http://ilovey.live/archives/Mysqlbackupshell

以上就是Mysql数据库定时备份脚本分享的详细内容,更多关于Mysql定时备份脚本的资料请关注脚本之家其它相关文章!

相关文章

  • 解决MySql客户端秒退问题(找不到my.ini)

    解决MySql客户端秒退问题(找不到my.ini)

    这篇文章主要介绍了解决MySql客户端秒退问题(找不到my.ini),本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • MySQL OOM 系列三 摆脱MySQL被Kill的厄运

    MySQL OOM 系列三 摆脱MySQL被Kill的厄运

    这篇文章主要介绍了MySQL OOM 系列三 摆脱MySQL被Kill的厄运 ,需要的朋友可以参考下
    2016-07-07
  • mysql常用命令大全 mysql常用命令总结

    mysql常用命令大全 mysql常用命令总结

    本文介绍下,mysql中常用的一些命令,包括创建与修改数据库、数据库中的表,mysql的权限管理命令grant、revoke等的用法。有需要的朋友参考下
    2014-01-01
  • MySQL8.0无法远程连接访问的解决方法

    MySQL8.0无法远程连接访问的解决方法

    本文主要介绍了MySQL8.0无法远程连接访问的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • Win7x64下Mysql5.7.18解压版的安装方法

    Win7x64下Mysql5.7.18解压版的安装方法

    这篇文章主要介绍了Win7x64下Mysql5.7.18解压版的安装方法,需要的朋友可以参考下
    2017-07-07
  • MySql按时,天,周,月进行数据统计

    MySql按时,天,周,月进行数据统计

    这篇文章主要介绍了MySql按时,天,周,月进行数据统计,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • MySQL复合索引的深入探究

    MySQL复合索引的深入探究

    这篇文章主要给大家介绍了关于MySQL复合索引的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Mysql中通用表达式WITH AS语句的使用实例代码

    Mysql中通用表达式WITH AS语句的使用实例代码

    with as也叫子查询,用来定义一个sql片段,且该片段会被整个sql语句反复使用很多次,这个sql片段就相当于是一个公用临时表,下面这篇文章主要给大家介绍了关于Mysql中通用表达式WITH AS语句使用的相关资料,需要的朋友可以参考下
    2022-08-08
  • MySQL 数据库 ALTER命令讲解

    MySQL 数据库 ALTER命令讲解

    MySQL 为关系型数据库(Relational Database Management System)。本文重点给大家介绍mysql数据库alert命令讲解,本文介绍的非常详细,具有参考借鉴价值,感兴趣的朋友一起学习吧
    2016-05-05
  • MySQL 从0到1打开数据库管理操作方法

    MySQL 从0到1打开数据库管理操作方法

    数据库管理系统(DataBase Management System)是用来创建数据库和管理数据库数据的一个管理软件,我们口头说的MySQL数据库就是这个管理系统,这篇文章主要介绍了MySQL从0到1打开数据库管理,需要的朋友可以参考下
    2023-06-06

最新评论