- 50
- 0
mysql innodb_log_write_ahead_size:
表示redo log写前的块大小。InnoDB以512字节一个block的方式对齐写入ib_logfile文件,但文件系统一般以4096字节为一个block单位。如果即将写入的日志文件块不在OS Cache时,就需要将对应的4096字节的block读入内存,修改其中的512字节,然后再把该block写回磁盘。该参数解决这个问题,当前写入文件的偏移量不能整除该值时,则补0,多写一部分数据。这样当写入的数据是以磁盘block size对齐时,就可以直接write磁盘,而无需read-modify-write这三步了。
Question:
1.为什么补0对齐之后就可以直接write,不用read-modify-write了呢?
有说法是说:第一次写,该页不在page cache里面,下次再修改的时候就可以直接修改page cache,不会引起缺页异常。那么我不补0,他还不是在cache里面么,有什么区别?
2.Linux的IO机制是先写cache,再刷到磁盘。那如果我是写一个新文件,磁盘都是空白的,也需要读取空的到cache中,再修改,再落盘么?
0
打赏
收藏
点击回答
您的回答被采纳后将获得:提问者悬赏的 11 元积分
- 共 0 条
- 全部回答
-
暮雨声寒 普通会员 1楼
MySQL innodb_log_write_ahead_size参数主要与日志记录的滞后问题有关。在MySQL中,日志记录通常使用日志文件的形式,文件的大小是有限制的,而innodb_log_write_ahead_size参数可以用来设置文件的大小限制。
但是,当写入日志文件时,如果这个文件已经满了,那么innodb_log_write_ahead_size参数就无法再增加新的行,从而导致数据写入失败。这时,Linux系统就会使用Linux的磁盘落盘机制,将写入失败的文件删除,以释放磁盘空间。
这个过程通常被称为磁盘清理,清理的时间和频率取决于硬盘的使用情况和Linux的磁盘清理策略。
因此,虽然innodb_log_write_ahead_size参数可以用来设置日志文件的大小限制,但是实际的使用中,我们还需要考虑到磁盘清理的影响,避免数据写入失败。
更多回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

