使用 Shell 脚本对 MySQL 数据库进行远程备份

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 使用 Shell 脚本对 MySQL 数据库进行远程备份

使用 Shell 脚本对 MySQL 数据库进行远程备份



一、Master 上操作


1.检查 MySQL 数据库端口是否开启

2.创建 MySQL 数据库密码

3.在 MySQL 数据库中创建库

4.配置 MySQL 数据库用户授权


二、Backup 上操作


1.安装 Mariadb 数据库

2.使用 mysqldump 进行远程备份测试


三、编写 Shell 脚本对 Master 数据库进行备份


四、通过计划任务来进行自动备份


准备工作:


image.png


一、Master 上操作



1.检查 MySQL 数据库端口是否开启


[root@Master ~]# netstat -anpt | grep 3306


image.png


2.创建 MySQL 数据库密码


[root@Master ~]# mysqladmin -uroot password '123'


image.png


3.在 MySQL 数据库中创建库


[root@Master ~]# mysql -uroot -p123
mysql> create database test1;
mysql> create database test2;  


image.png


4.配置 MySQL 数据库用户授权


mysql> grant all on test1.* to zhangsan@'192.168.1.%' identified by '123';
mysql> grant all on test2.* to lisi@'192.168.1.%' identified by '123456';
mysql> flush privileges;
mysql> exit;


image.png


二、Backup 上操作



1.安装 Mariadb 数据库


[root@Backup ~]# yum -y install mariadb                           # 安装系统自带 MySQL 数据库
[root@Backup ~]# mysql -uzhangsan -p123 -h192.168.1.1             # 验证远程登陆 MySQL
MySQL [(none)]> exit


image.png



2.使用 mysqldump 进行远程备份测试


[root@Backup ~]# mysqldump -uzhangsan -p123 -h192.168.1.1 test1 > test1.sql


image.png


三、编写 Shell 脚本对 Master 数据库进行备份



Backup 上操作:


[root@Backup ~]# mkdir /mysql.bak             # 创建备份目录
[root@Backup ~]# cd /mysql.bak                # 进入备份目录
[root@Backup mysql.bak]# vim mysql.sh           # 编写备份脚本
#!/bin/bash
#定义数据库连接. 目标库信息
my_user1="zhangsan"
my_user2="lisi"
my_pass1="123"
my_pass2="123456"
my_host="192.168.1.1"
my_conn1="-u $my_user1 -p$my_pass1 -h $my_host"
my_conn2="-u $my_user2 -p$my_pass2 -h $my_host"
my_db1="test1"
my_db2="test2"
# 定义备份目录. 工具. 时间. 文件主体
bf_dir="/mysql.bak"
bf_cmd="/usr/bin/mysqldump"
bf_time=`date +%F-%H-%M-%S`
name1="${my_db1}-$bf_time"
name2="${my_db2}-$bf_time"
# 先导出为.sql文件. 然后进行压缩(打包后删除原文件)
cd $bf_dir
$bf_cmd $my_conn1 --databases $my_db1 > ${name1}.sql
$bf_cmd $my_conn2 --databases $my_db2 > ${name2}.sql
/usr/bin/tar zcf ${name1}.tar.gz ${name1}.sql --remove &> /dev/null
/usr/bin/tar zcf ${name2}.tar.gz ${name2}.sql --remove &> /dev/null


[root@Backup mysql.bak]# chmod +x mysql.sh           # 添加可执行权限
[root@Backup mysql.bak]# ./mysql.sh                    # 执行该脚本
[root@Backup mysql.bak]# ls
mysql.sh  test1-2021-01-13-00-13-47.tar.gz  test2-2021-01-13-00-13-47.tar.gz


image.png


四、通过计划任务来进行自动备份



[root@Backup mysql.bak]# crontab  -e                      # 编辑计划任务
30 23 * * * /usr/bin/sh /mysql.bak/mysql.sh
[root@Backup mysql.bak]# crontab -l                   # 查看计划任务
30 23 * * * /usr/bin/sh /mysql.bak/mysql.sh
[root@Backup mysql.bak]# date -s '2021-01-13 23:29'           # 修改时间. 方便后续验证
2021年 01月 13日 星期三 23:29:00 CST
[root@Backup mysql.bak]# rm -rf test*                 # 删除原有备份数据
[root@Backup mysql.bak]# ls
mysql.sh
[root@Backup mysql.bak]# date
2021年 01月 13日 星期三 23:30:07 CST
[root@Backup mysql.bak]# ls
mysql.sh  test1-2021-01-13-23-30-01.tar.gz  test2-2021-01-13-23-30-01.tar.gz


image.png


  • 通过计划任务和编写的 Shell 脚本结合即可实现 MySQL 数据库自动备份。


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
6月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
456 158
|
6月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1094 152
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
850 156
|
6月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
459 156
|
6月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
548 161
|
7月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
6月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
6月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
6月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。