标签:内存 方案 逻辑 过程 磁盘 版本 缓冲池 删掉 img
由于WAL机制,InnoDB在更新语句的时候,制作了写日志这一个磁盘操作,就是redo log,在内存写完redo log后,就返回给客户端, 即更新成功。
把内存里的数据写入磁盘的过程,术语就是flush,在flush之前,实际数据和数据库中的数据是不一致的,因为在redo log基础上更新了还未写入,数据库是老的,当内存数据页跟磁盘数据页内容不一致的时候,称这个内存页为脏页,内存写入后就一致了,称为干净页,
如果mysql偶尔运行速度很慢,很可能是在刷脏页。引发数据库flush的过程
所以我们有时使用数据库会发现数据库性能突然下降,可能就是在处理脏页。
刷脏页控制策略
更新索引上的值也是删除一个旧的值,再插入一个新值,也会造成空洞。
收缩空间
新建一个与表A相同结构的表B,按照主键ID递增的顺序,把数据一行一行的从A里读出来再插入到表B中,表B中无空洞,数据页的利用率也更高,如果我们把表B作为临时表,数据从表A导入到B中的操作完成后,用B替换A,从效果上也起到了收缩A的作用。
在整个DDL过程中,表A不能有更新,所以这个DDL不是online的,在5.6之后的版本中,流程做了更改:
用临时文件替换表A的数据文件
图示
使用alter table A engine=InnoDB命令来重建表。在MySQL 5.5版本之前,这个命令的执行流程跟我们前面描述的差不多,区别只是这个临时表B不需要你自己创建,MySQL会自动完成转存数据、交换表名、删除旧表的操作。
标签:内存 方案 逻辑 过程 磁盘 版本 缓冲池 删掉 img
原文地址:https://www.cnblogs.com/jimmyhe/p/11072355.html