欢迎来到小居数码网-一家分享数码知识,生活小常识的网站,希望可以帮助到您。

当前位置:生活小常识 > 数码知识 >
优质

Mysql数据库备份脚本(mysql数据库备份数据)

数码知识

周嘉颖优秀作者

原创内容 来源:小居数码网 时间:2024-08-11 00:36:01 阅读() 收藏:24 分享:47

导读:您正在阅读的是关于【数码知识】的问题,本文由科普作家协会,生活小能手,著名生活达人等整理监督编写。本文有590个文字,大小约为3KB,预计阅读时间2分钟。

一、知识储备工作:

mysql数据库备份数据

  1. Mysql导出数据库语法:
mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql
  1. shell脚本if条件判断基本语法
  2. gzip压缩文件用法
  3. rsync异地备份用法:
  4. ssh免密登录

二、场景

本次利用shell脚本实现以下需求:

  1. 每天凌晨3点执行备份,需备份所有库
  2. 备份的数据存放在本地/data/backup下
  3. 将所有备份文件压缩,格式为gzip
  4. 压缩后的名称格式示例:mysql_bak.tar.gz
  5. 利用rsync实现异地备份
  6. 本地备份数据保留30天

三、MySQL数据库备份脚本

#!/bin/bash

#date: 20220120

set -e #错误时,便停止执行脚本

#数据库名,可以添加多个

EXCLUDE="Database|mysql|information_schema|performance_schema|sys"

USER="root"

PASSWORD="123456"

BACKUP_DIR=/data/backup

LOGFILE=/data/backup/data_backup.log

DATE=`date +%Y%m%d_%H%M`

cd $BACKUP_DIR

#写入日记文件

echo "--------------------" >> $LOGFILE

echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE

echo "-------------------" >> $LOGFILE

mysql -uroot -p${PASSWORD} -e "show databases"|grep -Ev ${EXCLUDE}|xargs mysqldump -uroot -p${PASSWORD} --routines --single_transaction --master-data=2 --databases > xzmysql_bak${DATE}.sql

if [ $? == 0 ];then

echo "$DATE--Database is backup succeed" >> $LOGFILE

else

echo "Database Backup Fail!" >> $LOGFILE

fi

cd $BACKUP_DIR

tar -czf xzmysql_bak${DATE}.tar.gz xzmysql_bak${DATE}.sql

rm -rf xzmysql_bak${DATE}.sql

#全部成功就同步到异地备份服务器

if [ $? == 0 ];then

rsync -avz --progress --password-file=/etc/rsync.password --exclude={*.log,*.txt} ${BACKUP_DIR}/* rsync_backup@192.168.10.51::xzmysqlbackup/192.168.10.128/

else

echo "Database Backup Fail!" >> $LOGFILE

fi

#删除30天以上的备份文件

find $BACKUP_DIR -type f -mtime +30 -name "*.gz" -exec rm -f {} ;

上面就是小居数码小编今天给大家介绍的关于(mysql数据库备份数据)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。

94%的朋友还想知道的:

(511)个朋友认为回复得到帮助。

部分文章信息来源于以及网友投稿,转载请说明出处。

本文标题:Mysql数据库备份脚本(mysql数据库备份数据):http://sjzlt.cn/shuma/154521.html

猜你喜欢