12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
ADADADADAD
mysql数据库 时间:2024-12-03 12:11:30
作者:文/会员上传
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
12-09
本文没有太多可读性,完全是自己的笔记一、现象延迟大,大事物。表结构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
11-20
11-19
11-20
11-20
11-20
11-19
11-20
11-20
11-19
11-20
11-19
11-19
11-19
11-19
11-19
11-19