• ADADADADAD

    MySQL:slave 延迟一列 外键检查和自增加锁[ mysql数据库 ]

    mysql数据库 时间:2024-12-03 12:11:30

    作者:文/会员上传

    简介:

    本文没有太多可读性,完全是自己的笔记一、现象延迟大,大事物。表结构image.png无IOimage.pngSQL THREAD占用CPU 100%image.png二、pscak 采样采样30个点外键检查 占70%image.p

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    本文没有太多可读性,完全是自己的笔记一、现象

    延迟大,大事物。

    表结构

    image.png

    无IO

    image.png

    SQL THREAD占用CPU 100%

    image.png

    二、pscak 采样

    采样30个点

    外键检查 占70%

    image.png

    自增锁获取 占30%

    image.png

    三、自增锁获取逻辑

    逻辑如下其实也是innodb_autoinc_lock_mode参数的作用

    switch(lock_mode){caseAUTOINC_NO_LOCKING://innodb_autoinc_lock_mode=2/*AcquireonlytheAUTOINCmutex.*/dict_table_autoinc_lock(m_prebuilt->table);break;caseAUTOINC_NEW_STYLE_LOCKING://innodb_autoinc_lock_mode=1注意这里没有break巧妙的完成了逻辑/*Forsimple(single/multi)rowINSERTs,wefallbacktotheoldstyleonlyifanothertransactionhasalreadyacquiredtheAUTOINClockonbehalfofaLOADFILEorINSERT...SELECTetc.typeofstatement.*/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;/*AcquiretheAUTOINCmutex.*/dict_table_autoinc_lock(ib_table);/*Weneedtocheckthatanothertransactionisn'talreadyholdingtheAUTOINClockonthetable.*/if(ib_table->n_waiting_or_granted_auto_inc_locks){/*Releasethemutextoavoiddeadlocks.*/dict_table_autoinc_unlock(ib_table);}else{break;}}/*Fallthroughtooldstylelocking.*/caseAUTOINC_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){/*AcquiretheAUTOINCmutex.*/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

    MySQL:slave 延迟一列 外键检查和自增加锁.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: mysqlslave一列