当前位置: 首页 > news >正文

MySQL空间报警后的一揽子解决方案

 这是学习笔记的第 2261 篇文章

读完需要

5

分钟

速读仅需7分钟

昨天下午的时候,收到一条报警信息,提示是一个异机房的从库出现了磁盘空间问题,这类问题看起来蛮好处理的,空间不够清理就是了,比如清理binlog,比如清理一些周期表等等。 

但是在经过分析之后,发现这个问题比预想的要严重。 

这是一套一主两从的环境,Slave2的配置相对较低,存储配置也略低一些,目前发生了磁盘空间的报警。

经过分析发现,原来是里面的一张表的数据量有了很大的变化,之前相对来说比较稳定,每天会生成50M~100M左右的数据,但是从近几天来看,数据量翻了好几百倍,每天乎有20~30G左右的数据写入,这样一来原来的存储模式就显得捉襟见肘了。

    怎么处理呢,一种模式就是磁盘扩容,这个时候我和业务侧做了沟通,准备细致了解一下。大体的需求是因为一些业务调整,需要记录的数据内容更全更丰富了,而这也是最近的一个新需求(此处的一个明显问题就是这个需求竟然和DBA没有任何沟通),因为目前采用的是日表,日表的保留周期是20天左右,最后能存储1个月,而从业务使用的角度来说,长期来看希望保留半年,这样一个需求,在目前的情况下几乎是不可实现的。 我们来简单算算,如果是保留20天,那么就需要至少600G以上的空间,外加一些冗余空间,差不多得在700~800G左右,而如果保留1个月就需要1T左右,而如果保留半年就需要大约6T左右。

   所以脑海里闪出几个方案:

1)对InnoDB的表进行压缩存储,压缩率高的话差不多能有40~50%左右,但是不能根本解决问题

2)使用数据库+数据仓库结合的方案,比如MySQL+Infobright的方案,MySQL中保留近2天的数据,数据按照T+1转储到数据仓库中,业务统计查询都从数仓中提取,优点是查询效率较高,缺点是查询复杂度比较高,比如有1个月的表,按照月,天的维度统计还是有些复杂的。 

3)使用基于中间件的分布式集群来进行数据写入水平扩展,整个集群的资源需求至少需要主从9个实例。

4)考虑使用MySQL+大数据流转的方案,即在MySQL中实时写入,数据通过Maxwell流转到Kafka中,然后进入大数据体系中进行消费,比如使用Impla等方案,可以做到比较高效的数据统计效果

整体经过讨论,最后采用了第4中方案,毕竟第2种方案需要重新配置和构建脚本逻辑,方案3没有解决统计查询的瓶颈问题,方案4解决了存储和统计查询的大问题。

QQ群号:763628645

QQ群二维码如下, 添加请注明:姓名+地区+职位,否则不予通过

订阅我的微信公众号“杨建荣的学习笔记”,第一时间免费收到文章更新。别忘了加星标,以免错过新推送提示。

   

近期热文

你可能也会对以下话题感兴趣。点击链接就可以查看。

相关文章:

  • 超12万人申请北京积分落户,顺带分析了一波近年的数据
  • MySQL中insert阻塞问题的分析
  • MySQL数据延迟跳动的问题分析
  • 彻底取代Redis+数据库架构,京东618稳了!
  • 一个扭蛋的故事
  • 做一次完美的数据迁移
  • 招贤纳士-第16期,来自北京和成都的职位
  • MySQL安装部署,从半成品状态的改进
  • 从SQL Server到TiDB的架构设计及对数据中台的思考
  • 近期的状态小结和最近要做的一些事情
  • 一次完整的JVM堆外内存泄漏故障排查记录
  • 35岁老码农:老板,你看我还有机会吗?
  • 打算搞一个简单的开源项目mysql_lite
  • 打开黑盒:从 MySQL 架构设计出发,看它是如何执行一条 SQL 语句的?
  • 手把手教你用 Jenkins + K8S 打造流水线环境
  • [分享]iOS开发 - 实现UITableView Plain SectionView和table不停留一起滑动
  • 77. Combinations
  • Android框架之Volley
  • angular2开源库收集
  • CentOS7简单部署NFS
  • JavaScript 事件——“事件类型”中“HTML5事件”的注意要点
  • JavaScript 是如何工作的:WebRTC 和对等网络的机制!
  • JS正则表达式精简教程(JavaScript RegExp 对象)
  • nodejs实现webservice问题总结
  • open-falcon 开发笔记(一):从零开始搭建虚拟服务器和监测环境
  • PAT A1120
  • Redis 中的布隆过滤器
  • SQLServer插入数据
  • Sublime Text 2/3 绑定Eclipse快捷键
  • swift基础之_对象 实例方法 对象方法。
  • Vue--数据传输
  • 闭包--闭包之tab栏切换(四)
  • 编写高质量JavaScript代码之并发
  • 动态规划入门(以爬楼梯为例)
  • 服务器从安装到部署全过程(二)
  • 力扣(LeetCode)56
  • 模型微调
  • 手写一个CommonJS打包工具(一)
  • 小程序测试方案初探
  • 《码出高效》学习笔记与书中错误记录
  • ionic异常记录
  • Spring Batch JSON 支持
  • 容器镜像
  • 组复制官方翻译九、Group Replication Technical Details
  • ​一些不规范的GTID使用场景
  • (02)Cartographer源码无死角解析-(03) 新数据运行与地图保存、加载地图启动仅定位模式
  • (C语言)输入一个序列,判断是否为奇偶交叉数
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • (附源码)springboot美食分享系统 毕业设计 612231
  • (附源码)ssm基于jsp的在线点餐系统 毕业设计 111016
  • (附源码)计算机毕业设计ssm基于B_S的汽车售后服务管理系统
  • (力扣题库)跳跃游戏II(c++)
  • (篇九)MySQL常用内置函数
  • (数据结构)顺序表的定义
  • (一)插入排序