当用户在客户端发起一个CRUD 操作时,InnoDB 引擎会转化为对页的访问。其中写的处理过程是怎样的?
步骤 1,根据Space ID 和Page No 计算页和缓冲池实例的对应关系。
步骤2,从Page Hash 中读取该页,若读取到该页则直接跳转到步骤5;若未能读取到,则继续。
步骤 3,从磁盘中读取对应的页。
步骤 4,从Free List 中获取空闲页,并用磁盘上读取到的数据进行填充。
步骤 5,如果页已经在缓冲池中,则根据LRU 策略调整其在List 上的位置;如果是新页,则将其添加到LRU List 的Old 区。
步骤 6,将页返回给用户线程。
步骤 7,用户线程对页进行修改,并调整Flush List。如果是已经在缓冲池中的页,则需要修改其newest_modification 字段;如果是新页,则直接将其添加到Flush List的头部。
步骤 8,返回客户端。
以上内容摘自《云原生数据库原理与实践》,这本书可以在电子工业出版社天猫店购买。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。