首页 > 数据库技术 > 详细

mysql源码系列~innodb_flush_log_at_trx_commit在底层实现

时间:2020-07-16 15:27:06      阅读:43      评论:0      收藏:0      [点我收藏+]

核心函数:trx_flush_log_if_needed_low
具体逻辑:
static void trx_flush_log_if_needed_low( lsn_t lsn) {
{
switch (srv_flush_log_at_trx_commit) {
case 0:
/* Do nothing */ 这里是由master线程的每1秒和每10秒算法进行日志的刷新,也就是master thread 每秒写到redo file中,然后由系统自行刷新到硬盘
break;
case 1:
/* Write the log and optionally flush it to disk */
log_write_up_to(lsn, LOG_WAIT_ONE_GROUP,
srv_unix_file_flush_method != SRV_UNIX_NOSYNC);
SRV_UNIX_NOSYNC, /*< do not flush after writing */ (可见这里刷新文件的方法不是这种模式 只写并不刷新)
SRV_UNIX_LITTLESYNC, /*(这里是调用方法)< do not call os_file_flush(when writing data files, but do flush after writing to log files */
break;
case 2:
/* Write the log but do not flush it to disk */
log_write_up_to(lsn, LOG_WAIT_ONE_GROUP, FALSE);
//在这里 srv_unix_file_flush_method=SRV_UNIX_NOSYNC

break;
default:
ut_error;
}
}
}
总结: mysql使用了枚举类型定义了不同的动作种类,然后通过switch case进行判断执行某些动作,核心变量 srv_unix_file_flush_method
文章源码来源参考: https://blog.csdn.net/innobase/article/details/51302145

mysql源码系列~innodb_flush_log_at_trx_commit在底层实现

原文:https://www.cnblogs.com/danhuangpai/p/13322339.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!