记阿里云mysql丢表丢数据的实践记录

第一时间挂工单,联系工程师指引,现在回过来想,第一时间要确认发生时间。

1.通过性能视图(马后炮的总结,实际凭记忆恢复了三四次才找到数据)

2.先恢复数据

通过Navicat工具,结构同步,数据同步恢复数据保证

3.原因排查

下载对应的Binlog日志文件

找到一台有mysql 5.7的库(注意与阿里云mysql的版本一致的)

怀疑的日志文件

参考指引

1.RDS MySQL实例实时生成本地日志(Binlog),当一个Binlog文件的大小超过 512 MB,或者写入超过6小时时,系统会自动切换到下一个序号的Binlog文件并继续写入。 参考;查看或删除MySQL本地日志(Binlog)_云数据库 RDS(RDS)-阿里云帮助中心

2.或者可以看下数据追踪,免费是近一个小时内可以追踪(更长时间涉及其他付费管控模式),可以追踪delete、update、insert 的语句的,drop没法追踪 数据追踪_数据管理(DMS)-阿里云帮助中心

binlog转sql的方法

复制代码
mysqlbinlog -vv --base64-output=decode-rows ats-mysql-bin.000872>000872.sql

排查语句,搜索丢失的表名快速定位语句

通过时间戳确定操作时间

4.其他问题

4.1执行binlog转sql的时候提示错误unknown variable 'default-character-set=utf8' 或者unknown variable 'character-set-server=utf8'

找到my.ini配置文件把default-character-set=utf8和character-set-server=utf8都注释掉,重启mysql再进行操作

4.2如何确定操作ip,操作账号,操作人?

基础版本不支持后台及时查看,需要升级高可用版本才行,配合信任ip可以减少非自主的操作

选择升级到高可用版本,高可用可以开启sql审计 升级高可用参考;基础系列升级为高可用系列_云数据库 RDS(RDS)-阿里云帮助中心 开启sql审计参考:https://help.aliyun.com/zh/rds/apsaradb-rds-for-mysql/use-the-sql-explorer-and-audit-feature-on-an-apsaradb-rds-for-mysql-instance?spm=a2c4g.11186623.0.i10

相关推荐
.Shu.27 分钟前
Mysql InnoDB 底层架构设计、功能、原理、源码系列合集【四、事务引擎核心 - MVCC与锁机制】
数据库·mysql
蓝黑20201 小时前
阿里云ECS服务器搭建ThinkPHP环境
服务器·阿里云·thinkphp
张鱼小丸子2 小时前
MySQL企业级部署与高可用实战
运维·数据库·mysql·云原生·高可用·mha·组从复制
GalaxyPokemon2 小时前
MYSQL的默认隔离级别都有什么
数据库·mysql
DONG9132 小时前
《三驾马车:MySQL、MongoDB、Redis对比与融合实战》
数据库·redis·sql·mysql·mongodb·database
Jasonakeke3 小时前
【重学MySQL】八十八、8.0版本核心新特性全解析
android·数据库·mysql
慧星云4 小时前
魔多 AI 上线提现功能 :将你的收益安稳入袋!
人工智能·云计算·aigc
JuiceFS5 小时前
JuiceFS writeback:写加速机制与适用场景解析
后端·云原生·云计算
小楓12015 小时前
MySQL數據庫開發教學(二) 核心概念、重要指令
开发语言·数据库·mysql
带你去吃小豆花5 小时前
20年AWS服务进化史
云计算·aws