我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL数据库定时备份脚本

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL数据库定时备份脚本

建议建立备份数据库的用户,本文使用root用户进行备份。

脚本内容如下:

vim mysql_back.sh

#!/bin/bash #指定连接数据库信息(用户名、密码、连接地址、端口、安装目录)DB_USER="root"DB_PWD="password"DB_IP="host"DB_PORT="3306"#是指mysqldump命令所在目录DB_DIR="/usr/local/mysql" #获取系统当前时间并格式化为:20210729BAK_DATE=`date +%Y%m%d` #指定备份文件保存的天数BAK_DAY=7#指定备份的数据库,可以指定多个中间用空格隔开,或者不指定则默认全部备份BAK_DATABASES=("")#指定备份路径BAK_PATH="/data/mysql_back" #创建备份目录mkdir ${BAK_PATH}/$BAK_DATE #开始执行备份echo "------- $(date +%F_%T) Start MySQL database backup-------- " >>${BAK_PATH}/back.log#循环遍历for database in "${BAK_DATABASES[@]}"do      ${DB_DIR}/bin/mysqldump -u${DB_USER} -p${DB_PWD} --host=${DB_IP} --port=${DB_PORT} --databases $database > ${BAK_PATH}/${BAK_DATE}/${database}.sqldone #创建压缩文件cd ${BAK_PATH}tar -zcPf db_backup_${BAK_DATE}.tar.gz $BAK_DATE #删除备份目录mv ${BAK_PATH}/$BAK_DATE /tmp1 #遍历备份目录下的文件LIST=$(ls ${BAK_PATH}/db_backup_*) #获取截止时间,将早于改时间的文件删除 SECONDS=$(date -d "$(date +%F) - ${BAK_DAY} days" +%s) for index in ${LIST}do   #获取文件名并格式化,获取时间,如20210729 timeString=$(echo ${index} | egrep -o "?[0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]") if [ -n "$timeString" ] then     indexDate=${timeString//./-}     indexSecond=$( date -d ${indexDate} +%s )     #与当前时间做比较,把早于7天的文件删除     if [ $(( $SECOND - $indexDate )) -gt 0 ]     then         rm -f $index        echo "-------deleted old file $index -------" >> ${BAK_PATH}/back.log     fi fidone echo "-------$(date +%F_%T) Stop MySQL database backup-------- " >>${BAK_PATH}/back.log 

查看日志文件:

cat /opt/mysql_back/back.log

cat /opt/mysql_back/back.log ------- 2021-07-29_18:25:09 Start MySQL database backup-------- -------2021-07-29_18:25:09 Stop MySQL database backup-------- 

查看备份文件:

ll /opt/mysql_back/

解压压缩包查看备份脚本。

tar -zxvf db_backup_20210729.tar.gz

确认备份文件没问题后设置定时任务可以实现定时备份:

crontab -e

crontab -e#每天凌晨3点执行备份,避免影响业务使用,备份时会锁表 0 3 * * * sh /root/mysql_back.sh

来源地址:https://blog.csdn.net/weixin_45100257/article/details/128476102

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL数据库定时备份脚本

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

BackUpMysql.sh脚本#!/bin/bash PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin export PATH#数据库ip DBHOST='
2022-05-31

MySQL 数据库备份脚本

MySQL 数据库备份脚本#!/bin/bash# 数据库连接信息DB_HOST="127.0.0.1"DB_PORT="3306"DB_USER="root"DB_PASSWD="root"# 时间格式化,如 20211216DATE="`date +%Y%
MySQL 数据库备份脚本
2015-10-18

shell脚本如何定时备份MySQL数据库数据并保留指定时间

这篇文章主要介绍shell脚本如何定时备份MySQL数据库数据并保留指定时间,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!公司用到的MySQL数据库,经常有同事通过一顿骚操作把一些关键的配置数据误删,每次恢复都要花上
2023-06-09

给Linux定时备份数据库的实现脚本

目录场景:服务器数据库需要实现每天定时备份1.首先确定备份脚本放置位置2.编写sh脚本3.给bash增加权限4.测试看看脚本是否是正确可执行的5.打开定时任务6.编辑内容7.查看定时任务 crontab -l8.踩坑服务器数据实现还原1.
2022-06-04

shell脚本实现mysql数据库双机定时备份的方法

目录1 缘起与目的2 确认环境2.1 导出数据库sql脚本2.2 跨机器拷贝2.3 docker容器确认环境3 构建脚本3.1 脚本内容3.2 手动执行脚本确认正常4 定时任务1 缘起与目的最近有个需求,要求实现对某个数据库进行双机备份,
2022-07-20

用python备份mysql数据库的脚本

一、前言             刚刚开始学python,还在看一套简单的python教学视频,但还未看完,简单的写了个mysql备份脚本,也算是第一个python脚本的×××座哈~~,因为才刚刚才开始,对python 的class 、fu
2023-01-31

编程热搜

目录