当InnoDB 引擎试图读取数据页时,会利用缓冲池实例的散列表进行查找,并分几种情况处理?
分三种情况处理:
• 当在散列表中定位到,即数据页在LRU List 中时,会判断数据页是在Old 区还是Young 区,如果数据页存在于Old 区,则在读取完数据页后把它添加到Young 区的链表头部。
• 如果在散列表中定位到并且数据页在Young 区,则需要判断数据页所在Young 区的位置,只有数据页处于Young 区总长度大约1/4 的位置之后,才会将其添加到Young 区的链表头部。
• 如果未能在散列表定位到,则需要在数据文件中读取数据页,并将其添加到Old 区的链表头部。
以上内容摘自《云原生数据库原理与实践》,这本书可以在电子工业出版社天猫店购买。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。