mysql binlog二進(jìn)制日志詳解
更新時(shí)間:2011年10月31日 23:13:00 作者:
二進(jìn)制日志包含了所有更新了數(shù)據(jù)或者已經(jīng)潛在更新了數(shù)據(jù)(例如,沒有匹配任何行的一個(gè)DELETE)的所有語(yǔ)句
基本概念
定義:
二進(jìn)制日志包含了所有更新了數(shù)據(jù)或者已經(jīng)潛在更新了數(shù)據(jù)(例如,沒有匹配任何行的一個(gè)DELETE)的所有語(yǔ)句。
作用:
1。二進(jìn)制日志的主要目的是在恢復(fù)使能夠最大可能地更新數(shù)據(jù)庫(kù),因?yàn)槎M(jìn)制日志包含備份后進(jìn)行的所有更新。
2。二進(jìn)制日志還用于在主復(fù)制服務(wù)器上記錄所有將發(fā)送給從服務(wù)器的語(yǔ)句。
不良影響:
運(yùn)行服務(wù)器時(shí)若啟用二進(jìn)制日志則性能大約慢1%。
如何啟動(dòng):
通過 –log-bin=file選項(xiàng)可以啟用
(更改my.ini文件)
日志位置
>>如果沒有指定文件名,則Mysql使用hostname-bin文件.
>>如果指定了相對(duì)路徑,則假定該路徑相對(duì)于數(shù)據(jù)目錄
>>Mysql在文件名后添加了數(shù)字索引.所以該文件最后的形式為filename.number
如果你在日志名中提供了擴(kuò)展名(例如,–log-bin=file_name.extension),則擴(kuò)展名被悄悄除掉并忽略。
更換策略:
使用索引來循環(huán)文件,在以下條件將循環(huán)至下一個(gè)索引
1。服務(wù)器重啟
2。服務(wù)器被更新
3。日志到達(dá)了最大日志長(zhǎng)度 max_binlog_size
4。日志被刷新 mysql> flush logs;
工具介紹:
shell>>mysqlbinlog [option] binlogFile> newfile
如: D:\mysql\log>mysqlbinlog binlog.000001 > 1.txt
一個(gè)例子:
log-bin=”D:/mysql/log/binlog” 那么,在該文件夾下就會(huì)有文件D:/mysql/log/binlog.000001等
常見問題
1.如何清除binlog
>>>使用下面的兩個(gè)命令
PURGE {MASTER | BINARY} LOGS TO ‘log_name' //log_name不會(huì)被清除
PURGE {MASTER | BINARY} LOGS BEFORE ‘date' //date不會(huì)被清除
實(shí)例如下:
mysql> purge master logs to ‘binlog.000004′;
Query OK, 0 rows affected (0.01 sec)
mysql> purge master logs before '2009-09-22 00:00:00′;
Query OK, 0 rows affected (0.05 sec)
>>>或使用命令
RESET MASTER
刪除之前所有的binlog,并重新生成新的binlog
后綴從000001開始
注:如果您有一個(gè)活性的從屬服務(wù)器,該服務(wù)器當(dāng)前正在讀取您正在試圖刪除的日志之一,
則本語(yǔ)句不會(huì)起作用,而是會(huì)失敗,并伴隨一個(gè)錯(cuò)誤。
不過,如果從屬服務(wù)器是休止的,并且您碰巧清理了其想要讀取的日志之一,則從屬服務(wù)器啟動(dòng)后不能復(fù)制。
當(dāng)從屬服務(wù)器正在復(fù)制時(shí),本語(yǔ)句可以安全運(yùn)行。您不需要停止它們。
2.記錄到二進(jìn)制日志知的內(nèi)容配置
binlog-do-db=sales 只記錄sales庫(kù)
binlog-ignore-db=sales 除sales庫(kù)不記錄,其他都記錄
但是如果在操作數(shù)據(jù)庫(kù)之前,不使用use $dbname 那么所有的SQL都不會(huì)記錄
如果使用了use $dbname,那么判斷規(guī)則取決于這里的$dbname,而不是SQL中操作的庫(kù)
3.二進(jìn)制日志不準(zhǔn)確的處理
默認(rèn)情況下,并不是每次寫入時(shí)都將二進(jìn)制日志與硬盤同步。因此如果操作系統(tǒng)或機(jī)器(不僅僅是MySQL服務(wù)器)崩潰,有可能二進(jìn)制日志中最后的語(yǔ)句丟失。
要想防止這種情況,你可以使用sync_binlog全局變量(1是最安全的值,但也是最慢的),使二進(jìn)制日志在每N次二進(jìn)制日志寫入后與硬盤同步。
即使sync_binlog設(shè)置為1,出現(xiàn)崩潰時(shí),也有可能表內(nèi)容和二進(jìn)制日志內(nèi)容之間存在不一致性。
如果崩潰恢復(fù)時(shí)MySQL服務(wù)器發(fā)現(xiàn)二進(jìn)制日志變短了(即至少缺少一個(gè)成功提交的InnoDB事務(wù)),
如果sync_binlog =1并且硬盤/文件系統(tǒng)的確能根據(jù)需要進(jìn)行同步(有些不需要)則不會(huì)發(fā)生,則輸出錯(cuò)誤消息 (“二進(jìn)制日志<名>比期望的要小”)。
在這種情況下,二進(jìn)制日志不準(zhǔn)確,復(fù)制應(yīng)從主服務(wù)器的數(shù)據(jù)快照開始。
定義:
二進(jìn)制日志包含了所有更新了數(shù)據(jù)或者已經(jīng)潛在更新了數(shù)據(jù)(例如,沒有匹配任何行的一個(gè)DELETE)的所有語(yǔ)句。
作用:
1。二進(jìn)制日志的主要目的是在恢復(fù)使能夠最大可能地更新數(shù)據(jù)庫(kù),因?yàn)槎M(jìn)制日志包含備份后進(jìn)行的所有更新。
2。二進(jìn)制日志還用于在主復(fù)制服務(wù)器上記錄所有將發(fā)送給從服務(wù)器的語(yǔ)句。
不良影響:
運(yùn)行服務(wù)器時(shí)若啟用二進(jìn)制日志則性能大約慢1%。
如何啟動(dòng):
通過 –log-bin=file選項(xiàng)可以啟用
(更改my.ini文件)
日志位置
>>如果沒有指定文件名,則Mysql使用hostname-bin文件.
>>如果指定了相對(duì)路徑,則假定該路徑相對(duì)于數(shù)據(jù)目錄
>>Mysql在文件名后添加了數(shù)字索引.所以該文件最后的形式為filename.number
如果你在日志名中提供了擴(kuò)展名(例如,–log-bin=file_name.extension),則擴(kuò)展名被悄悄除掉并忽略。
更換策略:
使用索引來循環(huán)文件,在以下條件將循環(huán)至下一個(gè)索引
1。服務(wù)器重啟
2。服務(wù)器被更新
3。日志到達(dá)了最大日志長(zhǎng)度 max_binlog_size
4。日志被刷新 mysql> flush logs;
工具介紹:
shell>>mysqlbinlog [option] binlogFile> newfile
如: D:\mysql\log>mysqlbinlog binlog.000001 > 1.txt
一個(gè)例子:
log-bin=”D:/mysql/log/binlog” 那么,在該文件夾下就會(huì)有文件D:/mysql/log/binlog.000001等
常見問題
1.如何清除binlog
>>>使用下面的兩個(gè)命令
PURGE {MASTER | BINARY} LOGS TO ‘log_name' //log_name不會(huì)被清除
PURGE {MASTER | BINARY} LOGS BEFORE ‘date' //date不會(huì)被清除
實(shí)例如下:
mysql> purge master logs to ‘binlog.000004′;
Query OK, 0 rows affected (0.01 sec)
mysql> purge master logs before '2009-09-22 00:00:00′;
Query OK, 0 rows affected (0.05 sec)
>>>或使用命令
RESET MASTER
刪除之前所有的binlog,并重新生成新的binlog
后綴從000001開始
注:如果您有一個(gè)活性的從屬服務(wù)器,該服務(wù)器當(dāng)前正在讀取您正在試圖刪除的日志之一,
則本語(yǔ)句不會(huì)起作用,而是會(huì)失敗,并伴隨一個(gè)錯(cuò)誤。
不過,如果從屬服務(wù)器是休止的,并且您碰巧清理了其想要讀取的日志之一,則從屬服務(wù)器啟動(dòng)后不能復(fù)制。
當(dāng)從屬服務(wù)器正在復(fù)制時(shí),本語(yǔ)句可以安全運(yùn)行。您不需要停止它們。
2.記錄到二進(jìn)制日志知的內(nèi)容配置
binlog-do-db=sales 只記錄sales庫(kù)
binlog-ignore-db=sales 除sales庫(kù)不記錄,其他都記錄
但是如果在操作數(shù)據(jù)庫(kù)之前,不使用use $dbname 那么所有的SQL都不會(huì)記錄
如果使用了use $dbname,那么判斷規(guī)則取決于這里的$dbname,而不是SQL中操作的庫(kù)
3.二進(jìn)制日志不準(zhǔn)確的處理
默認(rèn)情況下,并不是每次寫入時(shí)都將二進(jìn)制日志與硬盤同步。因此如果操作系統(tǒng)或機(jī)器(不僅僅是MySQL服務(wù)器)崩潰,有可能二進(jìn)制日志中最后的語(yǔ)句丟失。
要想防止這種情況,你可以使用sync_binlog全局變量(1是最安全的值,但也是最慢的),使二進(jìn)制日志在每N次二進(jìn)制日志寫入后與硬盤同步。
即使sync_binlog設(shè)置為1,出現(xiàn)崩潰時(shí),也有可能表內(nèi)容和二進(jìn)制日志內(nèi)容之間存在不一致性。
如果崩潰恢復(fù)時(shí)MySQL服務(wù)器發(fā)現(xiàn)二進(jìn)制日志變短了(即至少缺少一個(gè)成功提交的InnoDB事務(wù)),
如果sync_binlog =1并且硬盤/文件系統(tǒng)的確能根據(jù)需要進(jìn)行同步(有些不需要)則不會(huì)發(fā)生,則輸出錯(cuò)誤消息 (“二進(jìn)制日志<名>比期望的要小”)。
在這種情況下,二進(jìn)制日志不準(zhǔn)確,復(fù)制應(yīng)從主服務(wù)器的數(shù)據(jù)快照開始。
相關(guān)文章
mysql存儲(chǔ)emoji表情報(bào)錯(cuò)的處理方法【更改編碼為utf8mb4】
這篇文章主要介紹了mysql存儲(chǔ)emoji表情報(bào)錯(cuò)的處理方法,較為詳細(xì)的分析了通過更改mysql編碼為utf8mb4解決存儲(chǔ)emoji表情報(bào)錯(cuò)的相關(guān)操作技巧,需要的朋友可以參考下2018-07-07
mysql字段為NULL索引是否會(huì)失效實(shí)例詳解
有很多人對(duì)null值是否走索引感覺很疑惑,所以下面這篇文章主要給大家介紹了關(guān)于mysql字段為NULL索引是否會(huì)失效的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05
解決mysql錯(cuò)誤:Subquery?returns?more?than?1?row問題
這篇文章主要介紹了解決mysql錯(cuò)誤:Subquery?returns?more?than?1?row問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
MySQL8.0數(shù)據(jù)庫(kù)開窗函數(shù)圖文詳解
開窗函數(shù)為將要被操作的行的集合定義一個(gè)窗口,它對(duì)一組值進(jìn)行操作,不需要使用GROUP BY子句對(duì)數(shù)據(jù)進(jìn)行分組,能夠在同一行中同時(shí)返回基礎(chǔ)行的列和聚合列,這篇文章主要給大家介紹了關(guān)于MySQL8.0數(shù)據(jù)庫(kù)開窗函數(shù)的相關(guān)資料,需要的朋友可以參考下2023-06-06

