从之前的Mysql架构可以了解到,Mysql 客户端不是直接和磁盘打交道,我们在客户端输入的sql语句会被发送给服务端,服务端对sql语句进行解析、缓存等操作,然后再交由存储引擎去读写磁盘。这其实是从 C/S 的角度去了解Mysql。
站在OS的角度,Mysql 的数据保存在磁盘,本质还是文件IO,Mysql是如何跟内核(OS)打交道的呢?

目录
1、Mysql 交互模型(站在OS的角度)
核心理念说在最前面,Mysql 对数据所做的所有访问,无论是查询,还是增删改,都是在内存中进行的!
(1) Mysql 从磁盘读数据
早在Mysql 启动的时候,Mysql 就会向内存申请一块空间(下面统称“缓存池”)。
每次查询的时候,会预先从磁盘读取一部分相关数据到缓存池。(至于读取多少,详见“Mysql和磁盘交互的基本单位”)
每次

MySQL在与操作系统交互时,数据读写都在内存的缓存池中进行,以16KB的页为基本单位。查询时预读相关数据到缓存池,修改则先在内存中处理后刷新到内核缓冲区,内核按策略定期将数据写回磁盘。脏数据的立即或定时刷新,以及以页为单位的IO操作,旨在优化磁盘IO效率。
最低0.47元/天 解锁文章
390

被折叠的 条评论
为什么被折叠?



