iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎么理解MySQL中多源复制引起的内存泄漏
  • 592
分享到

怎么理解MySQL中多源复制引起的内存泄漏

2024-04-02 19:04:59 592人浏览 薄情痞子
摘要

怎么理解Mysql中多源复制引起的内存泄漏,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。场景 : mysql-5.7, 所有的小版本(&l

怎么理解Mysql中多源复制引起的内存泄漏,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。



场景 :
mysql-5.7, 所有的小版本(<=17), percona-mysql-5.7所有版本;
开启多源复制的只读实例的内存无限增长, 直到触发系统的OOM Kill;

结论 :
mysql bug, 附上bug单链接: https://bugs.mysql.com/bug.PHP?id=85371

现象描述 :
内存监控如图
怎么理解MySQL中多源复制引起的内存泄漏

问题原因:
目前只能基于现象来分析;

开启binlog_rows_query_log_events之后, 启用多源复制的slave会出现内存泄漏; 
表现为内存使用率不断增长: 占用内存的为slave_sql线程, 数据库事件为memory/sql/Log_event;


相关数据(来源于截图中的实例): 
重启只读slave之后, 相关事件的内存使用: 
申请了内存,但是没有释放过: COUNT_FREE, SUM_NUMBER_OF_BYTES_FREE为0


点击(此处)折叠或打开

  1. *************************** 2. row ***************************

  2.                    THREAD_ID: 18189

  3.                   EVENT_NAME: memory/sql/Log_event

  4.                  COUNT_ALLOC: 521692

  5.                   COUNT_FREE: 0

  6.    SUM_NUMBER_OF_BYTES_ALLOC: 117988604

  7.     SUM_NUMBER_OF_BYTES_FREE: 0

  8. ...

  9.     LOW_NUMBER_OF_BYTES_USED: 25286276

  10. CURRENT_NUMBER_OF_BYTES_USED: 117988604

  11.    HIGH_NUMBER_OF_BYTES_USED: 117988604

  12. *************************** 3. row ***************************

  13.                    THREAD_ID: 18183

  14.                   EVENT_NAME: memory/sql/Log_event

  15.                  COUNT_ALLOC: 521426

  16.                   COUNT_FREE: 0

  17.    SUM_NUMBER_OF_BYTES_ALLOC: 117732632

  18.     SUM_NUMBER_OF_BYTES_FREE: 0

  19. ...

  20.     LOW_NUMBER_OF_BYTES_USED: 25154914

  21. CURRENT_NUMBER_OF_BYTES_USED: 117732632

  22.    HIGH_NUMBER_OF_BYTES_USED: 117732632


两小时以后:


点击(此处)折叠或打开

  1. *************************** 1. row ***************************

  2.                    THREAD_ID: 18189

  3.                   EVENT_NAME: memory/sql/Log_event

  4.                  COUNT_ALLOC: 2297022

  5.                   COUNT_FREE: 0

  6.    SUM_NUMBER_OF_BYTES_ALLOC: 525744164

  7.     SUM_NUMBER_OF_BYTES_FREE: 0

  8. ...

  9.     LOW_NUMBER_OF_BYTES_USED: 25286276

  10. CURRENT_NUMBER_OF_BYTES_USED: 525744164

  11.    HIGH_NUMBER_OF_BYTES_USED: 525744164

  12. *************************** 2. row ***************************

  13.                    THREAD_ID: 18183

  14.                   EVENT_NAME: memory/sql/Log_event

  15.                  COUNT_ALLOC: 2296412

  16.                   COUNT_FREE: 0

  17.    SUM_NUMBER_OF_BYTES_ALLOC: 524600639

  18.     SUM_NUMBER_OF_BYTES_FREE: 0

  19. ...

  20.     LOW_NUMBER_OF_BYTES_USED: 25154914

  21. CURRENT_NUMBER_OF_BYTES_USED: 524600639

  22.    HIGH_NUMBER_OF_BYTES_USED: 524600639


event对应的线程:


点击(此处)折叠或打开

  1. *************************** 1. row ***************************

  2.         thd_id: 18183

  3.        conn_id: 18158

  4.           user: sql/slave_sql

  5.        command: Sleep

  6.          state: Slave has read all relay log; waiting for more updates

  7. current_memory: 532.28 MiB

  8. *************************** 2. row ***************************

  9.         thd_id: 18189

  10.        conn_id: 18164

  11.           user: sql/slave_sql

  12.        command: Sleep

  13.          state: Slave has read all relay log; waiting for more updates

  14. current_memory: 533.50 MiB

  15. 2 rows in set (0.10 sec)


解决方案 :
关闭binlog_rows_query_log_events(默认就是关闭的),
实际上这个参数主要是控制binlog中是否记录原始SQL语句的, 主要是Debug用;
而平时用-vv来解析binlog以后, 本身也会注明row模式中的SQL语句, 可读性也还可以接受;

这个bug目前是S2(Serious)

关闭这个配置以后, 内存变化如上图的后半部分, 基本可以看到不再有明显的上升趋势;
需要注意的是, 并不一定就不再有内存泄漏的问题了。

关于怎么理解MySQL中多源复制引起的内存泄漏问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网数据库频道了解更多相关知识。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么理解MySQL中多源复制引起的内存泄漏

本文链接: https://www.lsjlt.com/news/66266.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么理解MySQL中多源复制引起的内存泄漏
    怎么理解MySQL中多源复制引起的内存泄漏,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。场景 : MySQL-5.7, 所有的小版本(&l...
    99+
    2024-04-02
  • Java中怎么引入内存泄漏
    Java中怎么引入内存泄漏,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 什么是内存泄漏内存泄漏的定义:应用程序不再使用对象,但是垃圾收集器不能删除它们,因为它们正在被引用...
    99+
    2023-06-16
  • ThreadLocal在Tomcat中引起内存泄露怎么解决
    这篇文章主要介绍“ThreadLocal在Tomcat中引起内存泄露怎么解决”,在日常操作中,相信很多人在ThreadLocal在Tomcat中引起内存泄露怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
    99+
    2023-06-05
  • 对ThreadLocal内存泄漏及弱引用的理解
    ThreadLocal内存泄漏及弱引用 1.什么是内存泄漏?Entry的key弱引用与泄漏关系 在TreadLocal中内存泄漏是指TreadLocalMap中的Entry中的ke...
    99+
    2024-04-02
  • java多线程内存泄漏怎么解决
    Java中的内存泄漏问题通常是由于没有正确释放对象所引用的资源而导致的。下面是一些解决内存泄漏问题的常见方法: 及时释放资源:在...
    99+
    2023-10-27
    java
  • 如何解决EnyimMemcached异步化改造引起的内存泄漏问题
    如何解决EnyimMemcached异步化改造引起的内存泄漏问题,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。6月30日我们发布了异步化改造后的博客程序之后,出现了高内存、高C...
    99+
    2023-06-17
  • Java中怎么用弱引用堵住内存泄漏
    本篇内容主要讲解“Java中怎么用弱引用堵住内存泄漏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中怎么用弱引用堵住内存泄漏”吧!虽然用 Java™ 语言编写的程序在理论上是不会出现“内...
    99+
    2023-06-03
  • Java中的substring真的会引起内存泄露么
    这篇文章给大家介绍Java中的substring真的会引起内存泄露么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在Java中开发,String是我们开发程序可以说必须要使用的类型,String有一个substring...
    99+
    2023-06-17
  • Java的内存泄漏问题怎么解决
    本篇内容介绍了“Java的内存泄漏问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一问题的提出Java的一个重要优点就是通过垃圾收...
    99+
    2023-06-03
  • Python中的内存管理的原理和机制是什么,如何避免内存泄漏?
    Python中的内存管理的原理和机制是什么,如何避免内存泄漏?Python作为一门高级语言,通过自动内存管理提供了方便的编程环境。Python的内存管理主要依靠垃圾回收机制来实现,通过引用计数和循环垃圾回收来管理和释放内存。在Python中...
    99+
    2023-10-22
    内存管理:内存管理 原理:原理 内存泄漏:内存泄漏
  • C++技术中的内存管理:详解内存泄漏的预防措施
    c++++ 中的内存泄漏可以通过采取以下措施防止:了解指针、采用智能指针(如 unique_ptr、shared_ptr、weak_ptr)、谨慎使用裸指针、查找和修复内存泄漏(使用内存...
    99+
    2024-05-07
    c++ 内存管理 作用域
  • mysql复制和内存引擎的表是怎么样的
    mysql复制和内存引擎的表是怎么样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。当主服务器关闭并重新启动时,其内存表将变为空。要将此效...
    99+
    2024-04-02
  • C++技术中的内存管理:有效避免内存泄漏的解决方案是什么?
    c++++ 内存管理常见陷阱:内存泄漏,会导致应用程序崩溃。避免内存泄漏的解决方案:使用智能指针自动管理内存。运用 raii 资源管理技术确保对象超出作用域后释放资源。正确使用 new ...
    99+
    2024-05-07
    内存泄漏 内存管理 c++ 作用域
  • 怎么用JS理解IE的内存泄露
    这篇文章主要讲解了“怎么用JS理解IE的内存泄露”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用JS理解IE的内存泄露”吧!一、前言IE6~8除了不遵守...
    99+
    2024-04-02
  • 如何理解Go语言的HTTP标准库中的内存泄漏问题
    这篇文章给大家介绍如何理解Go语言的HTTP标准库中的内存泄漏问题,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。使用一个go库实现的一个http服务器:package mai...
    99+
    2024-04-02
  • mysql内存表无法主从复制怎么解决
    在MySQL中,内存表(Memory表)是一种特殊的表,数据存储在内存中而不是磁盘上,因此无法进行主从复制。如果您需要在主从复制环墶...
    99+
    2024-04-09
    mysql
  • 怎么理解MySQL中半同步引起Master实例Crash
    怎么理解MySQL中半同步引起Master实例Crash,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。场景 : Cr...
    99+
    2024-04-02
  • 怎么理解MySQL的GTID复制
    这篇文章主要介绍“怎么理解MySQL的GTID复制”,在日常操作中,相信很多人在怎么理解MySQL的GTID复制问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解MySQ...
    99+
    2024-04-02
  • 怎么理解Mysql GITD复制中断处理
    怎么理解Mysql GITD复制中断处理,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 从库发现复制错误:&nb...
    99+
    2024-04-02
  • MySQL中并行复制乱序提交引起的同步异常如何处理
    这篇文章将为大家详细讲解有关MySQL中并行复制乱序提交引起的同步异常如何处理,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。现象描述Slave在开启并行复制后, 默认会乱...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作