MySQL->>innodb_autoinc_lock_mode參數控制auto_increment 插入數據時相關鎖的模式

轉自 「 ITPUB博客 」 ,連接:http://blog.itpub.net/15498/viewspace-2141640/html

----------------------------------------------------------mysql

innodb_autoinc_lock_mode這個參數控制着在向有auto_increment 列的表插入數據時,相關鎖的行爲;


經過對它的設置能夠達到性能與安全(主從的數據一致性)的平衡

【0】咱們先對insert作一下分類


  首先insert大體上能夠分紅三類:
     一、simple insert 如insert into t(name) values('test')
    二、bulk insert 如load data | insert into ... select .... from ....
    三、mixed insert 如insert into t(id,name) values(1,'a'),(null,'b'),(5,'c');



【1】innodb_autoinc_lock_mode 的說明


  innodb_auto_lockmode有三個取值:
     一、0 這個表示tradition 傳統
     二、1 這個表示consecutive 連續
     三、2 這個表示interleaved 交錯


【1.1】tradition(innodb_autoinc_lock_mode=0) 模式:


   一、它提供了一個向後兼容的能力
   二、在這一模式下,全部的insert語句("insert like") 都要在語句開始的時候獲得一個
      表級的auto_inc鎖,在語句結束的時候才釋放這把鎖,注意呀,這裏說的是語句級而不是事務級的,一個事務可能包涵有一個或多個語句。
   三、它能保證值分配的可預見性,與連續性,可重複性,這個也就保證了insert語句在複製到slave
            的時候還能生成和master那邊同樣的值(它保證了基於語句複製的安全)。
       四、因爲在這種模式下auto_inc鎖一直要保持到語句的結束,因此這個就影響到了併發的插入。


【1.2】consecutive(innodb_autoinc_lock_mode=1) 模式:

  一、這一模式下去simple insert 作了優化,因爲simple insert一次性插入值的個數能夠立馬獲得
          肯定,因此mysql能夠一次生成幾個連續的值,用於這個insert語句;總的來講這個對複製也是安全的
          (它保證了基於語句複製的安全)
  二、這一模式也是mysql的默認模式,這個模式的好處是auto_inc鎖不要一直保持到語句的結束,只要
          語句獲得了相應的值後就能夠提早釋放鎖


【1.3】interleaved(innodb_autoinc_lock_mode=2) 模式
   一、因爲這個模式下已經沒有了auto_inc鎖,因此這個模式下的性能是最好的;可是它也有一個問題,就是
          對於同一個語句來講它所獲得的auto_increment值可能不是連續的。

【2】若是你的二進制文件格式是mixed | row 那麼這三個值中的任何一個對於你來講都是複製安全的。
   因爲如今mysql已經推薦把二進制的格式設置成row,因此在binlog_format不是statement的狀況下最好是innodb_autoinc_lock_mode=2 這樣可能知道更好的性能。

三種模式簡要說明:
0:traditonal (每次都會產生表鎖)
1:consecutive (會產生一個輕量鎖,simple insert會得到批量的鎖,保證連續插入)
2:interleaved (不會鎖表,來一個處理一個,併發最高)


總結:
1 innodb  row複製時,可將innodb_autoinc_lock_mode設置爲2,這時可在全部insert狀況下表得到最大併發度
2 innodb statement複製時,可將innodb_autoinc_lock_mode設置爲1,保證複製安全的同時,得到簡單insert語句的最大併發度
3 myisam引擎狀況下,不管什麼樣自增id鎖都是表級鎖,設置innodb_autoinc_lock_mode參數無效(測試略)
4 實際上提問者說到的在innodb引擎下自增id值做爲主鍵的狀況下,相比uuid或者自定義的主鍵,是能夠提到插入速度的,由於innodb是主鍵彙集索引,實際的主鍵值必須按照主鍵順序存取,那麼自增id自己就是升序的,那麼在插入數據時,底層就沒必要再作額外的排序操做,也減小了索引頁分裂的次數,從而大大增長insert速度(除非其餘方案也能保證主鍵徹底自增)
  



修改自增鎖級別方法:
編輯/etc/my.cnf,加入以下行:
innodb_autoinc_lock_mode=2


直接經過命令修改會報錯:
mysql(mdba@localhost:(none) 09:32:19)>set global innodb_autoinc_lock_mode=2;
ERROR 1238 (HY000): Variable 'innodb_autoinc_lock_mode' is a read only variablesql

 

參考文章:安全

MySQL自增鎖模式innodb_autoinc_lock_mode參數詳解併發

MySQL innodb_autoinc_lock_mode 詳解性能

相關文章
相關標籤/搜索