设为首页 收藏本站
查看: 649|回复: 0

[经验分享] mysql备份实例方案

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-11-24 08:39:03 | 显示全部楼层 |阅读模式
在线备份如何保障备份的数据的一致性,使用逻辑卷快照功能来实现,先锁几秒


把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支持多种不同的备份方式,包括物理备份,逻辑备份等方式,通过在生产环境中一般都是采用物理备份和逻辑备份相结合的方式来实现



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-304719-1-1.html 上篇帖子: mysql管理之安全机制 下篇帖子: mysql表常用操作 mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表