等待事件:log file sync

发布时间:2020-08-12 00:12:41 作者:tietouwa
来源:ITPUB博客 阅读:332

       当用户进程提交时,会通知LGWR将redo buffer写入到redo file中,当LGWR进程完成写入操作后,LGWR在通知用户进程写入完成。用户进程接收到LGWR通知后才会完成提交。因此用户进程在没有收到LGWR通知之前一直处于等待状态,就会产生log file sync。


      1、commit

      2、每隔3秒钟将日志缓冲区输出

      3、当日志缓存区已写满三分之一时

      4、在DBWR将脏数据写入到数据文件之前

      5、当log buffer 大于1M时


        1、频繁的提交或rollback,检查应用是否有过多的短小的事物,如果有,可以使用批处理来缓解

        2、过大的日志缓冲区,因为log buffer中的数据量无法达到log_io_size,导致更多的重做条目堆积在日志缓冲区,此时当事务提交或3s醒来时,LGWR会把所有数据都写入到redo file中,由于数量过多,LGWR要用更多的时间等待redo写完完毕(此种情况可以调小log_io_size参数,其默认值是log_buffer 的1/3或1M,去两者中较小的值。)——可以具有很大的日志缓冲区,但较小的log_io_size将增加后台写入次数,从而减少log file sync的等待时间。

        3、CPU负载高,LGWR无法及时获取CPU调度,出现 log file sync

        4、log file sync 平均等待时间超过7ms,说明log write 每次写入时间过长


        1、查看日志提交是否频繁,如果过于频繁应尽量减少commit

        2、确保CPU资源充足

        3、建议加大日志缓冲区

        4、优化redo日志文件存储,存放在更快的磁盘上


推荐阅读:
  1. log file sync事件
  2. Script to Collect Log File Sync Diagnostic Information (lfsdiag.sql)

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

file log sync

上一篇:Influxdb中Select查询请求结果涉及到的一些数据结构

下一篇:基于TimeLine模型的消息同步机制

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》