mysql备份实例方案

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介:

在线备份如何保障备份的数据的一致性,使用逻辑卷快照功能来实现,先锁几秒

 

 

blog日志重定向到一个文件里,再用source导入到数据库里,因为每操作一步都会产生新的blog日志

物理备份:

直接复制数据库文件,适用于大型数据库环境,一般结构lvm snapshot的方式实现,缺点是不能恢复到异构系统中如Windows

逻辑备份

备份的是建表,建库,插入等操作所执行的sql语句,适用于中小型数据库,效率比较低

 

Mysqldump实现逻辑备份

语法

#mysqldump -h 服务器 -u用户名  -p密码 数据库名 备份文件.sql

 

数据库名的选项

--all -databases   所有库

School   数据库名

School stu_info t1 school数据库的表stu_info t1

--databases bbs test mysql 多个数据库

 

实例:

单库备份:

#mysqldump -uroot -p123 bbs >bbs.sql

#mysqldump -uroot -p123 bbs table1 table 2 > bbs table1 table2.sql

 

多库备份

#mysqldump -uroot -p123 -databases bbs test mysql > bbs_test_mysql,sql

 

备份所有库

#mysqldump -uroot -p123 --all-databases > all.sql

 

#mysqldump -uroot -p123 --all-databses --lock-all-tables > /tmp/all2.sql

 

备份/恢复案例:

情况1数据库损坏了,等于是机器都坏了

操作步骤:

备份

1#mysqldump -uroot -p123 --all-databases --lock-all-tables>/backup/`date+%F`_all.sql

2mysql -uroot -p123 -e flush logs   //截断并产生新的binlog

3插入数据   //模拟服务器正常运行

4mysql>set sql_log_bin=0;

Mysql>drop database bbs   //模拟服务器损坏

 

恢复:(干净的环境,新机器)

1mysql>set sql_log_bin=0;

 Mysql>source /backup/2014-02-13 all.sql            //恢复最近一次完全备份

2mysqlbinlog 最后一个binlog |mysql -uroot -p 123     //恢复最后一个binlog文件

 

 

情况2如果有误删除

备份

1#mysqldump -uroot -p123 --all-databases --lock-all-tables>/backup/`date+%F`_all.sql

2mysql -uroot -p123 -e flush logs   //截断并产生新的binlog

3插入数据   //模拟服务器正常运行

4Mysql>drop table db1.t1  //模拟误删除

 

恢复:(干净的环境,新机器)

1mysql>set sql_log_bin=0;

 Mysql>source /backup/2014-02-13 all.sql            //恢复最近一次完全备份

2mysqlbinlog 最后一个binlog  --stop-position=260|mysql -uroot -p 123  

mysqlbinlog 最后一个binlog  --start-position=500|mysql -uroot -p 123    这种情况下就需要用到blog字符截取来恢复

 

 

备份/恢复注意事项:

1)完全备份到一个干净的环境(例如新的数据库或删除原有的数据库)

2)恢复期间所有sql语句不应该记录到binlog

3)单库恢复前需要手动创建数据库

实现自动化备份

1)写脚本

Vim /mysql_back.sql

#!/bin/Bash

#The mysql_back

# Author: luliechu E-mail: 983765387@qq.com

Back_dir=/backup

Back_file=`date+%F`_all.sql

User=root

Pass=123

If[! -d /backup];

Then

 Mkdir -p /backup

Fi

 

#备份并切断日志

Mysqldump -u${user} -p${pass} -- events --all-databases --lock-all-tables>${back_dir}/${back_file}

Mysql  -u${user}  -p${pass} -e flush logs

 

#只保留最近一周的备份

Cd $back_dir

Find -mtime +7 -exec rm -rf {}\;

 

 

2)测试

Chmod a+x /mysql_back.sql //給脚本执行权限

Chattr +i /mysql_back.sql   //为了安全给这脚本文件上锁,禁止任何人做改动

/mysql_back.sql    //执行脚本

3)配置定时任务到生产环境中

Crontab  -l

0 2 * * * /mysql_back.sql   //每天凌晨2点执行脚本

导出表

将表导入到文本文件中

表的导出和导入

Select ....into outfile 导出文本文件

实例:

Mysql>select * from school.student1

Into outfile student1.txt

Fields terminated by `,`   //定义字段分割符

Optinon

Ally enclosed by `’’定义字符串使用什么符号括起来

Lines terminated by \n  //定义换行符

 

 

数据库迁移

注意要尽量是相同版本之间迁移

 

Mysqldump -h 迁移源ip -uroot -p123 --databases bbs |mysql -h 目标ip  -uroot

 -p456

//迁移源为本机,不用申请

总结:mysql支持多种不同的备份方式,包括物理备份,逻辑备份等方式,通过在生产环境中一般都是采用物理备份和逻辑备份相结合的方式来实现

本文转自    探花无情   51CTO博客,原文链接:http://blog.51cto.com/983865387/1875829


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
16天前
|
存储 关系型数据库 MySQL
【赵渝强老师】使用select...into outfile语句备份MySQL
本文介绍了MySQL中使用`SELECT...INTO OUTFILE`语句将表数据导出为文本文件的方法。通过示例演示了如何备份员工表(emp)的数据,包括创建存储目录、设置权限、配置参数`secure_file_priv`以及解决相关错误的过程。字段分隔符和行终止符可自定义,确保数据格式符合需求。最后展示了备份文件的内容,验证操作成功。
106 36
|
4月前
|
关系型数据库 MySQL Shell
MySQL 备份 Shell 脚本:支持远程同步与阿里云 OSS 备份
一款自动化 MySQL 备份 Shell 脚本,支持本地存储、远程服务器同步(SSH+rsync)、阿里云 OSS 备份,并自动清理过期备份。适用于数据库管理员和开发者,帮助确保数据安全。
|
16天前
|
存储 SQL 关系型数据库
【赵渝强老师】使用mysqldump备份MySQL
本文介绍了 MySQL 自带的逻辑备份工具 mysqldump 的使用方法。通过 mysqldump,可以将数据库中的数据转换为对应的 SQL 插入语句,便于备份和还原。文章详细说明了如何备份所有数据库、指定数据库及特定表,排除某些表不备份的操作,以及删除数据库后如何通过备份文件恢复数据。同时提供了视频讲解和具体命令示例,帮助用户更好地理解和应用该工具。
|
15天前
|
存储 SQL 关系型数据库
【赵渝强老师】使用mydumper备份MySQL
本文介绍了使用mydumper工具进行MySQL数据库备份与恢复的操作方法。相比单线程工作的mysqldump,mydumper支持多线程,速度提升可达10倍。其功能包括事务性表快照、快速压缩、导出binlog等,并提供详细的参数说明和操作步骤。文章通过实例演示了安装mydumper、创建存储目录、全库备份、指定数据库及表备份、删除数据库以及使用myloader恢复数据的完整流程,并附带视频讲解,帮助用户更好地理解和应用该工具。
|
3月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
180 28
|
3月前
|
存储 关系型数据库 MySQL
利用Cron表达式实现MySQL数据库的定时备份
以上就是如何使用Cron表达式和mysqldump命令实现MySQL数据库的定时备份。这种方法的优点是简单易用,而且可以根据需要定制备份的时间和频率。但是,它也有一些限制,例如,它不能备份MySQL服务器的配置文件和用户账户信息,也不能实现增量备份。如果需要更复杂的备份策略,可能需要使用专门的备份工具或服务。
79 15
|
3月前
|
SQL Oracle 关系型数据库
在MySQL Shell里 重启MySQL 8.4实例
在MySQL Shell里 重启MySQL 8.4实例
78 2
|
17天前
|
人工智能 运维 关系型数据库
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
115 1
|
2月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
4月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库

推荐镜像

更多