MySQL非常重要的日志bin log詳解
bin log全稱binary log,二進制日志文件,它記錄了數據庫所有執行的 DDL 和 DML 等數據庫更新的語句,但是不包含select或者show等沒有修改任何數據的語句。它是MySQL級別的日志,也就是說所有的存儲引擎都會產生bin log,而redo log或者undo log事務日志只有innoDB存儲引擎才有。
那bin log有什么用呢?
數據恢復,如果MySQL數據庫意外掛了,可以利用bin log進行數據恢復,因為該日志記錄所有數據庫所有的變更,保證數據的安全性。數據復制,利用一定的機制將主節點MySQL的日志數據傳遞給從節點,實現數據的一致性,實現架構的高可用和高性能。所以bin log對于數據備份、主從、主主等都都起到了關鍵作用。
看了上面的bin log介紹,是不是感覺和事務日志redo log特別像呢?也是在事務執行的時候記錄日志,但是他們還是有區別的。
你知道redo log嗎, 如果不了解的話請參考這篇文章:詳解MySQL事務日志redo log_Mysql_好吧啦網 (jb51.net)
我們現在從多個角度對比下他們倆究竟有什么不一樣?
從使用場景角度來說:
redo log主要實現故障情況下的數據恢復,保證事務的持久性bin log主要用于數據災備、同步從數據內容角度來說:
redo log是"物理日志", 記錄的是具體數據頁上做了什么修改bin log是"邏輯日志", 記錄內容是語句的原始邏輯,類似于“給 ID=2 這一行的 name 改為alvin”從生成范圍角度來說:
redo log是InnoDB存儲引擎生成的事務日志,其他存儲引擎沒有bin log是MySQL Server生成的日志,所有的存儲引擎都有從生成時機角度來說:
redo log是在事務執行過程中就會writebin log是在事務提交的時候writebin log怎么寫的?那bin log是什么時候寫的,寫入的機制又是怎么樣的呢?
bin log寫入的整體流程如下圖所示:
3種刷盤策略:
bin log和 redo log類似,都有3種刷盤策略, bin log的write和fsync時機是由參數 sync_binlog 控制,默認是 0 。
sync_binlog = 0為0的時候,表示每次提交事務都只 write,由系統自行判斷什么時候執行fsync。雖然性能得到提升,但是機器宕機,page cache里面的 binglog 會丟失。
sync_binlog = 1我們已經知道,事務執行時會同時記錄redo log和bin log兩種日志,那會有日志出錯不一致問題嗎?
假如事務執行sqlupdate T set c = 1 where id = 2,在寫完redo log日志后,bin log日志寫期間發生了異常,會出現什么情況呢?
由于bin log沒寫完就異常,這時候bin log里面沒有對應的修改記錄。因此,之后用bin log日志恢復數據時,就會少這一次更新,恢復出來的這一行c值為0,而原庫因為redo log日志恢復,這一行c的值是1,最終數據不一致。
那有什么解決方案嗎?二階段提交方案。
為了解決兩份日志之間的一致性問題,InnoDB存儲引擎使用兩階段提交方案。將redo log的寫入拆成了兩個步驟prepare和commit。
前面講解了bin log寫入的過程,那么它寫到了哪里去了呢?
查看bin log位置可以通過命令show variables like '%log_bin%';查看bin log最終輸出的位置。
通過 SHOW BINARY LOGS;查看當前的二進制日志文件列表及大小,如下圖:
修改MySQL的my.cfg或my.ini配置
#啟用二進制日志log-bin=cxw-binbinlog_expire_logs_seconds=600max_binlog_size=100Mlog-bin: bin log日志保存的位置binlog_expire_logs_seconds: bin log日志保存的時間,單位是秒max_binlog_size: 單個bin log日志的容量bin log內容長啥樣?我們已經知道了bin log的位置了,那它里面的內容長什么樣呢?
我們可以用show binlog events命令工具查看bin log日志中的內容。
show binlog events [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count];IN 'log_name' :指定要查詢的binlog文件名(不指定就是第一個binlog文件)FROM pos :指定從哪個pos起始點開始查起(不指定就是從整個文件首個pos點開始算)LIMIT [offset] :偏移量(不指定就是0)row_count :查詢總條數(不指定就是所有行)bin log 格式
實際上bin log輸出的格式類型有3種,默認是ROW類型,就是上面例子中的格式。
本文講解了MySQL中的一個非常重要的日志bin log,它主要用來做數據恢復和同步的,所以作為程序員的我們,還是很有必要對它有一個深入的認識。
以上就是MySQL非常重要的日志bin log詳解的詳細內容,更多關于MySQL日志bin log的資料請關注好吧啦網其它相關文章!
