mysql备份实例方案-阿里云开发者社区

开发者社区> 技术小牛人> 正文

mysql备份实例方案

简介:
+关注继续查看

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

 

 

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


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
SQL Server 数据库定时自动备份
原文:SQL Server 数据库定时自动备份 SQL Server 数据库定时自动备份——每天定时备份,保留前8天的备份 利用SQL Server代理新建作业来定期备份 1)在数据库库的【SQL Server代理】->【作业】,右键【新建作业】 2)在【常规】选项卡设置【名称】(自定义) ...
1049 0
sql server 完整备份、差异备份、事务日志备份
原文:sql server 完整备份、差异备份、事务日志备份 一、 理解:        完整备份为基础, 完整备份可以实物回滚还原,但是由于完整备份文件过大,对硬盘空间比较浪费这是就需要差异备份 或者 事务日志备份。
1153 0
SQL Server 批量完整备份
原文:SQL Server 批量完整备份 一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现代码(SQL Codes) 实现方式一(One) 实现方式二(Two) 实现方式三(Three) 参考文献(References) 二.
961 0
MySQL分析实例解读
MySQL分析实例是由RDS MySQL 与AnalyticDB for MySQL联合打造,产品级深度融合的OLTP+OLAP解决方案,解决MySQL客户复杂分析查询卡顿问题。一键购买,权限打通,自动数据同步,业务库毫无感知和影响情况下数据自动实时同步到分析库。
3189 0
SQL远程备份
原文:SQL远程备份 set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go   -- ============================================= -- Author: dcrenl -- Create date: ...
730 0
利用mysqldump 实现每天备份方案
1.创建单独的导出导入数据库帐号 grant SELECT, RELOAD, SHOW DATABASES, LOCK TABLES on game to jackluo@localhost identified by 'jackluo'; grant SELECT, REL...
530 0
MySQL 多实例的安装
MySQL 多实例的安装Step 1 . 准备工作关闭防火墙; 安装 MySQL依赖于libaio 库;下载,解压,重命名 MySQL的执行文件;新建用户组和用户 等准备工作在此不再赘述。 可执行文件目录为 /data/mysql57 添加用户和组的指令 groupadd mysql useradd mysql -g mysql Step 2 . 添加环境变量在/etc/profile文件中,追加 PATH=${PATH}:/data/mysql57/bin/ 保存后,如需要立即生效,可执行 source /etc/profile 。
1340 0
5723
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《Nacos架构&原理》
立即下载
《看见新力量:二》电子书
立即下载
云上自动化运维(CloudOps)白皮书
立即下载