首页 > 其他分享 >KingbaseES V8R6 等待事件之LWLock Buffer_IO

KingbaseES V8R6 等待事件之LWLock Buffer_IO

时间:2023-05-09 19:44:22浏览次数:45  
标签:读取 V8R6 Buffer KingbaseES BufferIO LWLock 事件 共享 等待

等待事件含义

当进程同时尝试访问相同页面时,等待其他进程完成其输入/输出(I/O)操作时,会发生LWLock:BufferIO等待事件。其目的是将同一页读取到共享缓冲区中。

每个共享缓冲区都有一个与LWLock:BufferIO等待事件相关联的I/O锁,每次都必须在共享缓冲区外部检索页。

此锁用于处理多个会话,假如这些会话都需要访问同一块。必须从共享缓冲池外部读取此块,共享缓冲池大小由shared_buffers参数定义。

一旦在共享缓冲池中读取到页面,就会释放LWLock:BufferIO锁。

注意:

LWLock:BufferIO等待事件先于IO:DataFileRead等待事件。从存储读取数据时发生IO:DataFileRead等待事件。

等待事件增加的可能原因

多个后端进程或连接试图访问正在进行I/O活动的同一页面

共享缓冲池的太小,大型或膨胀的索引,需要向共享缓冲池中读取比膨胀前更多的数据。

缺少索引,这迫使数据库引擎从表中读取的页面超过了必要的数量。

检查点出现频率太高或需要刷新太多脏块

试图在同一页面上执行操作的数据库连接突然出现峰值,造成并发争用问题

解决方法

根据等待事件的原因,我们建议采取以下操作:

shared_buffer中的HitRatiio急剧下降和LWLock:BufferIO等待事件之间存在相关性。这种效果可能需要增加shard_buffer大小。还可以应用读写分离集群分摊数据库负载到不同实例。

如果您看到LWLock:BufferIO增加与BufferCacheHitRatio指标下降,则根据您的工作负载峰值时间调整max_wal_size和checkpoint_timeout。然后确定可能是哪个查询导致的。

验证是否有未使用的或不必要的索引,然后将其删除。

使用分区表(应用分区索引)。这样做有助于尽量低的将索引重新排序,并减少其影响。

通过使用连接池来防止突然的数据库连接高峰。

作为最佳方案,限制与数据库的最大连接数。并适时中断连接,释放内存。

标签:读取,V8R6,Buffer,KingbaseES,BufferIO,LWLock,事件,共享,等待
From: https://www.cnblogs.com/kingbase/p/17273773.html

相关文章

  • KingbaseES V8R3 集群运维系列 -- failover切换后集群自动恢复
    ​案例说明:KingbaseESV8R3集群默认在触发failover切换后,为保证数据安全,原主库需要通过人工介入后,恢复为新的备库加入到集群。在无人值守的现场环境,需要在触发failover切换后,主库可以自动恢复为新备考加入集群,提升架构的高可用性。适用版本:KingbaseESV8R3集群架构:node_id......
  • Linux中Buffer和Cache的区别
    Linux中Buffer和Cache的区别1.cache,缓存区,是高速缓存。是位于CPU和主内存之间的容量较小但速度很快的存储器,因为CPU的速度远远高于主内存的速度,CPU从内存中读取数据需等待很长的时间,而 Cache保存着CPU刚用过的数据或循环使用的部分数据,这时从Cache中读取数据会更快,减少了CPU......
  • Go源码阅读——github.com/medcl/esm —— buffer.go
    esm(AnElasticsearchMigrationTool)—— buffer.gohttps://github.com/medcl/esmrelease:8.7.1通过阅读好的源代码,细致思考,理性分析并借鉴优秀实践经验,提高zuoyang的编程水平,所谓"他山之石,可以攻玉" 该是如此吧。 /*CopyrightMedcl(mATmedcl.net)Licensedun......
  • MySQL双写缓冲区(Doublewrite Buffer)
    本文已收录至Github,推荐阅读......
  • (转)Java中的String、StringBuilder和StringBuffer
    1、StringString对象是不可变的,即一旦一个String对象被创建以后,包含在这个对象中的字符序列是不可改变的,直至这个对象被销毁。那么我们new一个String对象,比如Stringa=newString("A")Stringa2=newString("A")和直接创建一个字符串,比如Stringb="A"这两种方......
  • 浅谈Protocol Buffers、GRPC、Buf、GRPC-Gateway
    1.ProtocolBuffers什么是proto?ProtocolBuffers如何理解ProtocolBuffers?协议缓冲区非proto协议如何订立、传播以及维护?如何理解协议缓冲区?Protocolbuffers提供了一种语言中立、平台中立、可扩展的机制,用于以向前兼容和向后兼容的方式序列化结构化数据。它......
  • 金仓数据库KingbaseES 两表关联Update的两种写法与性能
    原文链接:https://blog.csdn.net/arthemis_14/article/details/127886142熟悉oracle的人都知道,对于两表的关联更新,其执行计划主要有Filter和OuterJoin两种方式。对于大批量数据的update,Join方式明显是更优的选择。KingbaseES也支持两种方式的关联update,语法上采用两种不同......
  • String、StringBuilder、StringBuffer
    String真正不可变有下面几点原因:保存字符串的数组被final修饰且为私有的,并且String类没有提供/暴露修改这个字符串的方法。String类被final修饰导致其不能被继承,进而避免了子类破坏String不可变。String:不可变,线程安全StringBuilder:可变,单线程,线程不安全StringBuf......
  • MySQL 8.0中InnoDB buffer pool size进度更透明
    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。GreatSQL是MySQL的国产分支版本,使用上与MySQL一致。作者:Yejinrong/叶金荣文章来源:GreatSQL社区原创MySQL8.0upupup~从MySQL5.7开始,支持在线动态调整innodbbufferpool,并为此新增了一个状态变......
  • CMU 15445 Buffer Pool
    task1实现LRU-kEvivt,从缓冲里淘汰掉一个页当缓冲满的时候RecordAcess,记录下这个访问的页的页id以及时间戳当一个页被访问时,需要进行pin,一般这个操作位于pin之后Remove,清空一个页的历史访问记录当一个页被从BFM中删除时才调用SetEvictable,设置......