本文没有太多可读性,完全是自己的笔记 一、现象 延迟大,大事物。 表结构 image.png 无io image.png sql TH
延迟大,大事物。
image.png
采样30个点
外键检查 占70%
image.png
自增锁获取 占30%
image.png
逻辑如下其实也是innodb_autoinc_lock_mode参数的作用
switch (lock_mode) { case AUTOINC_NO_LOCKING://innodb_autoinc_lock_mode=2
dict_table_autoinc_lock(m_prebuilt->table); break; case AUTOINC_NEW_STYLE_LOCKING: // innodb_autoinc_lock_mode=1 注意这里没有break 巧妙的完成了逻辑
if (thd_sql_command(m_user_thd) == SQLCOM_INSERT
|| thd_sql_command(m_user_thd) == SQLCOM_REPLACE) {
dict_table_t* ib_table = m_prebuilt->table;
dict_table_autoinc_lock(ib_table);
if (ib_table->n_waiting_or_granted_auto_inc_locks) {
dict_table_autoinc_unlock(ib_table);
} else { break;
}
}
case AUTOINC_OLD_STYLE_LOCKING://innodb_autoinc_lock_mode=0 触发
DBUG_EXECUTE_IF("die_if_autoinc_old_lock_style_used",
ut_ad(0););
error = row_lock_table_autoinc_for_Mysql(m_prebuilt); //这个函数上表上的自增锁
if (error == DB_SUCCESS) {
dict_table_autoinc_lock(m_prebuilt->table);
} break; default:
ut_error;
}
binlog row格式,innodb_autoinc_lock_mode=1 按理说不会触发row_lock_table_autoinc_for_mysql加自增锁。不知道什么原因。当前知道:
如果主库语句模式,从库innodb_autoinc_lock_mode=1 ,insert select 肯定会触发。
如果从库 innodb_autoinc_lock_mode=0 肯定会触发。
但是都不满足。疑惑。
删除外键
innodb_autoinc_lock_mode设置为2,从逻辑来看肯定不会做row_lock_table_autoinc_for_mysql了。
作者微信:
微信.jpg
--结束END--
本文标题: MySQL:slave 延迟一列 外键检查和自增加锁
本文链接: https://lsjlt.com/news/49715.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0