我们不止要说误删数据的事后处理办法,更重要是要做到事前预防
误删数据分类
使用 delete 语句误删数据行
使用 drop table 或者 truncate table 语句误删数据表
使用 drop database 语句误删数据库
使用 rm 命令误删整个 MySQL 实例
需要完善自动恢复脚本
一种加速的方法是,在用备份恢复出临时实例之后,将这个临时实例设置成线上备库的从库
#1.恢复全量备份
a.指定全量备份路径
b.写入全量备份名称
c.恢复全量备份到指定临时实例
在 start slave 之前,先通过执行change replication filter replicate_do_table = (tbl_name) 命令,就可以让临时库只同步误操作的表
这样做也可以用上并行复制技术,来加速整个数据恢复过程
#2.自动恢复binlo
a.指定binlog备份路径
b.指定需要恢复的binlog名称(1个或者多个)
c.恢复binlog到指定临时实例
复制
预防误删库 表的方法
第一条建议是,账号分离。这样做的目的是,避免写错命令
比如:我们只给业务开发同学 DML 权限,而不给 truncate/drop 权限。
而如果业务开发人员有 DDL 需求的话,也可以通过开发管理系统得到支持。
即使是 DBA 团队成员,日常也都规定只使用只读账号,必要的时候才使用有更新权限的账号。第二条建议是,制定操作规范
这样做的目的,是避免写错要删除的表名。
比如:在删除数据表之前,必须先对表做改名操作。然后,观察一段时间,确保对业务无影响以后再删除这张表。
改表名的时候,要求给表名加固定的后缀(比如加 _to_be_deleted),然后删除表的动作必须通过管理系统执行。并且,管理系删除表的时候,只能删除固定后缀的表。
End
本文分享内容是我自己的一些见解,欢迎大家一起来评论留言探讨,我会不定期更新内容,大家可以关注我哟~,也可以在今日头条搜索“青雨果果”关注我!~

向上滑动


文章转载自青雨果果,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【专家有话说第五期】在不同年龄段,DBA应该怎样规划自己的职业发展?
墨天轮编辑部
1222次阅读
2025-03-13 11:40:53
MySQL8.0统计信息总结
闫建(Rock Yan)
456次阅读
2025-03-17 16:04:03
2月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
440次阅读
2025-03-13 14:38:19
Ogg23ai高手必看-MySQL Innodb Cluster跟oracle的亲密接触
曹海峰
437次阅读
2025-03-04 21:56:13
SQL优化 - explain查看SQL执行计划(一)
金同学
378次阅读
2025-03-13 16:04:22
MySQL突然崩溃?教你用gdb解剖core文件,快速锁定“元凶”!
szrsu
323次阅读
2025-03-13 00:29:43
MySQL生产实战优化(利用Index skip scan优化性能提升257倍)
chengang
310次阅读
2025-03-17 10:36:40
一键装库脚本3分钟极速部署,传统耗时砍掉95%!
IT邦德
225次阅读
2025-03-10 07:58:44
MySQL8.0直方图功能简介
Rock Yan
213次阅读
2025-03-21 15:30:53
MySQL 有没有类似 Oracle 的索引监控功能?
JiekeXu
188次阅读
2025-03-19 23:43:22