账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    MySQL innodb_log_write_ahead_size参数及Linux落盘机制的疑问
    • 2020-01-01 00:00
    • 11
    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参数可以用来设置日志文件的大小限制,但是实际的使用中,我们还需要考虑到磁盘清理的影响,避免数据写入失败。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部