mysql性能優化之-innodb_flush_log_at_trx_commit


innodb_flush_log_at_trx_commit是配置MySql日志何時寫入硬盤的參數:

一、參數值說明

0:log buffer將每秒一次地寫入log file中,並且log file的flush(刷到磁盤)操作同時進行。該模式下在事務提交的時候,不會主動觸發寫入磁盤的操作。

1:每次事務提交時MySQL都會把log buffer的數據寫入log file,並且flush(刷到磁盤)中去,該模式為系統默認。

2:每次事務提交時mysql都會把log buffer的數據寫入log file,但是flush(刷到磁盤)操作並不會同時進行。該模式下,MySQL會每秒執行一次 flush(刷到磁盤)操作

 

二、參數修改

找到mysql配置文件mysql.ini,修改成合適的值,然后重啟mysql。

 

三、注意事項 

當設置為0,該模式速度最快,但不太安全,mysqld進程的崩潰會導致上一秒鍾所有事務數據的丟失。
當設置為1,該模式是最安全的,但也是最慢的一種方式。在mysqld 服務崩潰或者服務器主機crash的情況下,binary log 只有可能丟失最多一個語句或者一個事務。。
當設置為2,該模式速度較快,也比0安全,只有在操作系統崩潰或者系統斷電的情況下,上一秒鍾所有事務數據才可能丟失。
 

四、其他相關

查找資料時候看到其他文章說innodb_flush_log_at_trx_commit和sync_binlog 兩個參數是控制MySQL 磁盤寫入策略以及數據安全性的關鍵參數,當兩個參數都設置為1的時候寫入性能最差,推薦做法是 innodb_flush_log_at_trx_commit=2,sync_binlog=500 或1000
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM