mysql 重要日志文件匯總
作者:丁儀
來(lái)源:https://chengxuzhixin.com/blog/post/mysql_zhong_yao_ri_zhi_wen_jian_zong_jie.html
日志是所有應(yīng)用的重要數(shù)據(jù),MySQL 也有錯(cuò)誤日志、查詢?nèi)罩尽⒙樵內(nèi)罩尽⑹聞?wù)日志等。本文簡(jiǎn)單總結(jié)下各種日志,以備查閱。
二進(jìn)制日志 binlog
二進(jìn)制日志 binlog 用于記錄數(shù)據(jù)庫(kù)執(zhí)行的寫入性操作(不包括查詢)信息,以二進(jìn)制的形式保存在磁盤中。使用任何存儲(chǔ)引擎的 mysql 數(shù)據(jù)庫(kù)都會(huì)記錄 binlog 日志。在 binlog 中記錄的是邏輯日志,也就是 SQL 語(yǔ)句。SQL 語(yǔ)句執(zhí)行后,binlog 追加到日志文件中??梢栽O(shè)置 binlog 文件大小,超過(guò)大小后,自動(dòng)創(chuàng)建新的文件。
binlog 有三種格式,分別為 STATMENT、ROW 和 MIXED。
- STATMENT:把會(huì)修改數(shù)據(jù)的 sql 語(yǔ)句記錄到 binlog 中;是 MySQL 5.7.7 之前的默認(rèn)格式;
- ROW:不記錄每條 sql 語(yǔ)句的上下文信息,僅記錄哪條數(shù)據(jù)被修改了;是 MySQL 5.7.7之后的默認(rèn)格式;
- MIXED:基于 STATMENT 和 ROW 兩種模式的混合復(fù)制,一般使用 STATEMENT 模式,對(duì)于無(wú)法復(fù)制的操作使用 ROW 模式;
在實(shí)際應(yīng)用中,binlog 主要用于主從復(fù)制和數(shù)據(jù)恢復(fù)。主從復(fù)制是指在 master 機(jī)器開啟 binlog,通過(guò)某種方式把 binlog 發(fā)送給 slave 機(jī)器,slave 機(jī)器根據(jù) binlog 內(nèi)容進(jìn)行數(shù)據(jù)操作,從而保證主從數(shù)據(jù)一致性。另外,通過(guò)使用 mysqlbinlog 工具可以從 binlog 恢復(fù)數(shù)據(jù)。
在 MySQL 5.7 之后,內(nèi)置默認(rèn)引擎已經(jīng)變更為 InnoDB 引擎。 InnoDB 引擎在處理事務(wù)時(shí),可以設(shè)置日志寫入磁盤的時(shí)機(jī),默認(rèn)情況下是每次 commit 時(shí)寫入磁盤。也可以通過(guò) sync_binlog 參數(shù)設(shè)置成系統(tǒng)自動(dòng)判斷或每 N 個(gè)事務(wù)寫入一次。
查詢?nèi)罩?br />
查詢?nèi)罩居涗浟怂袛?shù)據(jù)庫(kù)請(qǐng)求的信息。無(wú)論這些請(qǐng)求是否得到了正確的執(zhí)行。開啟之后對(duì)性能有比較大的影響,因此使用不多。
慢查詢?nèi)罩?/strong>
慢查詢?nèi)罩居脕?lái)記錄執(zhí)行時(shí)間超過(guò)某個(gè)閾值的語(yǔ)句。執(zhí)行時(shí)間閾值可以通過(guò) long_query_time 來(lái)設(shè)置,默認(rèn)是 10 秒。慢查詢?nèi)罩拘枰謩?dòng)開啟,對(duì)性能有一些影響,一般不建議開啟。慢查詢?nèi)罩局С謱⒂涗泴懭胛募?,也支持寫入?shù)據(jù)庫(kù)表。
事務(wù)日志 redo log
事務(wù)的四大特性之一是持久性。因此事務(wù)成功后,數(shù)據(jù)庫(kù)的修改永久保存,不能因?yàn)槿魏卧蚨氐皆瓉?lái)的狀態(tài)。redo log 是 InnoDB 引擎層實(shí)現(xiàn)的日志,并不是所有引擎都有,用來(lái)記錄事務(wù)對(duì)數(shù)據(jù)頁(yè)的修改,可以在崩潰時(shí)用于恢復(fù)數(shù)據(jù)。redo log 包括內(nèi)存中的日志緩沖和磁盤上的日志文件。執(zhí)行 SQL 語(yǔ)句后,先寫入日志緩沖,后續(xù)再一次性把多條緩沖寫入文件。
在 InnoDB 中,數(shù)據(jù)頁(yè)也會(huì)刷盤,redo log 存在的意義主要就是降低對(duì)數(shù)據(jù)頁(yè)刷盤的要求。數(shù)據(jù)頁(yè)的變更,redo log 沒有必要全部保存。如果數(shù)據(jù)頁(yè)刷盤比 redo log 快,則 redo log 的記錄對(duì)于數(shù)據(jù)恢復(fù)意義不大;如果數(shù)據(jù)頁(yè)刷盤比 redo log 慢,則 redo log 中比數(shù)據(jù)頁(yè)快的部分可以用來(lái)快速恢復(fù)數(shù)據(jù)。因此 redo log 日志文件大小是固定的,當(dāng)寫到結(jié)尾時(shí),會(huì)回到開頭循環(huán)寫日志。
事務(wù)日志 undo log
事務(wù)的四大特性之一是原子性。對(duì)數(shù)據(jù)庫(kù)的一系列操作,要么全部成功,要么全部失敗,不允許部分成功部分失敗。因此,需要記錄數(shù)據(jù)的邏輯變化。原子性通過(guò) undo log 來(lái)實(shí)現(xiàn),比如事務(wù)中執(zhí)行一條 insert 語(yǔ)句,undo log 就會(huì)記錄一條 delete 語(yǔ)句;事務(wù)中執(zhí)行一條 update 語(yǔ)句,undo log 就會(huì)記錄一條相反的 update 語(yǔ)句。這樣在事務(wù)失敗時(shí),就可以通過(guò) undo log 來(lái)回滾到事務(wù)之前的狀態(tài)。
以上就是mysql 重要日志文件匯總的詳細(xì)內(nèi)容,更多關(guān)于MySQL 日志文件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Mysql數(shù)據(jù)庫(kù)函數(shù)之函數(shù)的用法小結(jié)
函數(shù)只是對(duì)查詢結(jié)果中的數(shù)據(jù)進(jìn)行處理,不會(huì)改變數(shù)據(jù)庫(kù)中數(shù)據(jù)表的值,MySQL中的函數(shù)主要分為單行函數(shù)和多行函數(shù)兩大類,下面我們將詳細(xì)講解這兩大類函數(shù),這篇文章主要介紹了Mysql數(shù)據(jù)庫(kù)函數(shù)之函數(shù)的用法,需要的朋友可以參考下2022-11-11Ubuntu上安裝MySQL+問(wèn)題處理+安全優(yōu)化
這篇文章主要匯總介紹了Ubuntu上安裝MySQL+問(wèn)題處理+安全優(yōu)化的相關(guān)事項(xiàng),非常的細(xì)致全面,有需要的小伙伴可以參考下2016-03-03Mysql子查詢關(guān)鍵字的使用方式(exists)
這篇文章主要介紹了Mysql子查詢關(guān)鍵字的使用方式(exists),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07SQLyog連接MySQL8.0+報(bào)錯(cuò):錯(cuò)誤號(hào)碼2058的解決方案
本文將總結(jié)如何解決 SQLyog 連接 MySQL8.0+ 時(shí)報(bào)錯(cuò):錯(cuò)誤號(hào)碼2058,文中通過(guò)圖文結(jié)合和代碼示例給大家總結(jié)了三種解決方案,具有一定的參考價(jià)值,需要的朋友可以參考下2023-12-12