MySQL【实践 01】Linux 环境 MySQL 数据库备份 shell 脚本(脚本源码及说明+定时任务配置+数据库恢复测试)粘贴可以

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL【实践 01】Linux 环境 MySQL 数据库备份 shell 脚本(脚本源码及说明+定时任务配置+数据库恢复测试)粘贴可以

数据库备份的重要性不言而喻,备份的方法主要分为两大类,一是文件备份,二是数据库本身的备份机制binlog日志,今天先说说文件备份,就是将数据库【结构和数据】导出为文件。

1.备份脚本

在 /data/backup 下编写备份脚本 mysql_backup.sh 尽量不要在Windows环境下编写 shell 脚本,会有编码不对的问题,内容如下【备注已很清晰】:

#!/bin/bash
source /etc/profile
# 以下配置信息需要根据自己情况进行编辑
mysql_user="root"             # 备份用户
mysql_password="root@2021"    # 备份用户的密码
mysql_port="3306"             # 端口
mysql_charset="utf8"          # 编码
backup_db_arr=("xxxbase")     # 要备份的数据库名称,多个用空格分开隔开 如("dba" "dbb" "dbc")
backup_location=/data/backup  # 备份数据存放位置,末尾请不要带"/"
expire_backup_delete="ON"     # 是否开启过期备份删除 ON为开启 OFF为关闭
expire_days=7                 # 过期时间天数 默认为三天,此项只有在expire_backup_delete开启时有效
# 本行开始以下不需要修改
backup_time=`date +%Y%m%d%H%M`                    #定义备份详细时间
backup_Ymd=`date +%Y-%m-%d`                       #定义备份目录中的年月日时间
backup_3ago=`date -d '3 days ago' +%Y-%m-%d`      #3天之前的日期
backup_dir=$backup_location/$backup_Ymd           #备份文件夹全路径
welcome_msg="Welcome to use MySQL backup tools!"  #欢迎语
# 判断MYSQL是否启动 mysql没有启动则备份退出 【这里可以学到查询某服务是否运行的命令】
mysql_ps=`ps -ef |grep mysql |wc -l`
mysql_listen=`netstat -an |grep LISTEN |grep $mysql_port|wc -l`
if [ [$mysql_ps == 0] -o [$mysql_listen == 0] ]; then
        echo "ERROR:MySQL is not running! backup stop!"
        exit
else
        echo $welcome_msg
fi
# 连接到mysql数据库 无法连接则备份退出 【使用的是数据步本身的工具】
mysql -P$mysql_port -u$mysql_user -p$mysql_password <<end
use mysql;
select host,user from user where user='root' and host='localhost';
exit
end
flag=`echo $?`
if [ $flag != "0" ]; then
        echo "ERROR:Can't connect mysql server! backup stop!"
        exit
else
        echo "MySQL connect ok! Please wait......"
        # 判断有没有定义备份的数据库,如果定义则开始备份,否则退出备份
        if [ "$backup_db_arr" != "" ];then
                #dbnames=$(cut -d ',' -f1-5 $backup_database)
                #echo "arr is (${backup_db_arr[@]})"
                for dbname in ${backup_db_arr[@]}
                do
                        echo "database [ $dbname ] backup start..."
                        `mkdir -p $backup_dir`
                        `mysqldump -P$mysql_port -u$mysql_user -p$mysql_password $dbname --default-character-set=$mysql_charset | gzip > $backup_dir/$dbname-$backup_time.sql.gz`
                        flag=`echo $?`
                        if [ $flag == "0" ];then
                                echo "database $dbname success backup to $backup_dir/$dbname-$backup_time.sql.gz"
                        else
                                echo "database $dbname backup fail!"
                        fi
                done
        else
                echo "ERROR:No database to backup! backup stop"
                exit
        fi
        # 如果开启了删除过期备份,则进行删除操作
        if [ "$expire_backup_delete" == "ON" -a "$backup_location" != "" ];then
                 #`find $backup_location/ -type d -o -type f -ctime +$expire_days -exec rm -rf {} \;`
                 `find $backup_location/ -type d -mtime +$expire_days | xargs rm -rf`
                 echo "Expired backup data delete complete!"
        fi
        echo "All database backup success! Thank you!"
        exit
fi

2.定时任务

给 mysql_backup.sh 文件赋予可执行权限。

chmod -R 777 mysql_backup.sh

Linux的 cron 表达式跟Java的 cron 表达式不同,这里要注意。

# m h dom mon dow command
# 分 时 日 月 周    要执行的命令
# 编辑定时任务列表
crontab -e
  # 添加以下文本(每天00:00执行mysql_backup.sh脚本)
  00 00 * * * /data/backup/mysql_backup.sh
# 重启 cron 服务
sudo service crond restart

3.脚本测试

直接执行备份脚本进行测试,我备份了两个数据库 backup_db_arr=(“xxl_job” “jeecg-boot”) 这里看一下效果:

[root@aliyun backup]# ./mysql_back.sh
Welcome to use MySQL backup tools!
mysql: [Warning] Using a password on the command line interface can be insecure.
host    user
localhost       root
MySQL connect ok! Please wait......
database [ xxl_job ] backup start...
mysqldump: [Warning] Using a password on the command line interface can be insecure.
database xxl_job success backup to /data/backup/2021-07-24/xxl_job-202107241712.sql.gz
database [ jeecg-boot ] backup start...
mysqldump: [Warning] Using a password on the command line interface can be insecure.
database jeecg-boot success backup to /data/backup/2021-07-24/jeecg-boot-202107241712.sql.gz
Expired backup data delete complete!
All database backup success! Thank you!
[root@aliyun backup]# ll
total 4
drwxr-xr-x 2 root root   79 Jul 24 17:12 2021-07-24
-rwxrwxrwx 1 root root 3429 Jul 24 17:12 mysql_back.sh
[root@aliyun backup]# cd ./2021-07-24/
[root@aliyun 2021-07-24]# ll
total 88
-rw-r--r-- 1 root root 83689 Jul 24 17:12 jeecg-boot-202107241712.sql.gz
-rw-r--r-- 1 root root  2757 Jul 24 17:12 xxl_job-202107241712.sql.gz

执行后生成了两个SQL文件【jeecg-boot-202107241712.sql.gz】和【xxl_job-202107241712.sql.gz】

4.数据恢复

删除数据库 xxl_job、jeecg-boot 下的所有表和数据,执行导入命令,输入密码即可:

# 解压
gunzip xxl_job-202107241712.sql.gz
# 导入
mysql -uroot -p xxl_job < xxl_job-202107241712.sql
Enter password:
xxx

查看数据库发现数据已经恢复,这种定时备份数据库的方式是有缺陷的,随后会写一篇使用数据库 binlog 文件恢复数据的方法。

目录
打赏
0
0
0
0
276
分享
相关文章
【Linux】vim使用与配置教程
Vim是一款功能强大的文本编辑器,广泛应用于Linux环境,是开发者和系统管理员的必备工具。本文介绍了Vim的基本操作与简单配置,涵盖命令模式、插入模式和底行模式的使用方法,以及光标定位、复制粘贴、搜索替换等常用技巧。同时,文章还提供了实用的分屏操作和代码注释方法,并分享了通过`.vimrc`文件进行个性化配置(如显示行号、语法高亮、自动缩进等)的技巧,帮助用户提升文本编辑效率。掌握这些内容,能让Vim更好地服务于日常工作与开发需求。
37 3
在Rocky Linux 9上安装JDK并配置环境变量!
本教程介绍在Rocky Linux 9上安装JDK并配置环境变量的完整步骤。首先更新系统,清理旧版本JDK相关包及残留文件,确保环境干净。接着搜索并安装所需版本的JDK(如OpenJDK 17),验证安装是否成功。然后查找JDK安装路径,配置全局环境变量`JAVA_HOME`和`PATH`,最后验证环境变量设置。按照此流程操作,可顺利完成Java开发环境搭建,支持多版本切换(如JDK 8/11/17)。生产环境请谨慎操作,避免影响现有服务。
59 21
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
|
1月前
|
问题记录:解决Linux登录故障,/etc/passwd配置受损该怎么操作
修复/etc/passwd文件是解决Linux登录故障的重要步骤。通过进入单用户模式、挂载文件系统、恢复或手动修复/etc/passwd文件,可以有效解决该问题。保持定期备份系统配置文件是预防此类问题的最佳实践。
62 13
|
1月前
|
问题记录:解决Linux登录故障,/etc/passwd配置受损该怎么操作
修复/etc/passwd文件是解决Linux登录故障的重要步骤。通过进入单用户模式、挂载文件系统、恢复或手动修复/etc/passwd文件,可以有效解决该问题。保持定期备份系统配置文件是预防此类问题的最佳实践。
58 5
|
3月前
|
Linux网络文件系统NFS:配置与管理指南
NFS 是 Linux 系统中常用的网络文件系统协议,通过配置和管理 NFS,可以实现跨网络的文件共享。本文详细介绍了 NFS 的安装、配置、管理和常见问题的解决方法,希望对您的工作有所帮助。通过正确配置和优化 NFS,可以显著提高文件共享的效率和安全性。
375 7
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
114 82
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)

热门文章

最新文章