欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql binlog二進(jìn)制日志詳解

 更新時間:2011年10月31日 23:13:00   作者:  
二進(jìn)制日志包含了所有更新了數(shù)據(jù)或者已經(jīng)潛在更新了數(shù)據(jù)(例如,沒有匹配任何行的一個DELETE)的所有語句
基本概念
定義:
二進(jìn)制日志包含了所有更新了數(shù)據(jù)或者已經(jīng)潛在更新了數(shù)據(jù)(例如,沒有匹配任何行的一個DELETE)的所有語句。

作用:
1。二進(jìn)制日志的主要目的是在恢復(fù)使能夠最大可能地更新數(shù)據(jù)庫,因為二進(jìn)制日志包含備份后進(jìn)行的所有更新。
2。二進(jìn)制日志還用于在主復(fù)制服務(wù)器上記錄所有將發(fā)送給從服務(wù)器的語句。
不良影響:
運行服務(wù)器時若啟用二進(jìn)制日志則性能大約慢1%。

如何啟動:
通過 –log-bin=file選項可以啟用
(更改my.ini文件)
日志位置
>>如果沒有指定文件名,則Mysql使用hostname-bin文件.
>>如果指定了相對路徑,則假定該路徑相對于數(shù)據(jù)目錄
>>Mysql在文件名后添加了數(shù)字索引.所以該文件最后的形式為filename.number
如果你在日志名中提供了擴(kuò)展名(例如,–log-bin=file_name.extension),則擴(kuò)展名被悄悄除掉并忽略。

更換策略:
使用索引來循環(huán)文件,在以下條件將循環(huán)至下一個索引
1。服務(wù)器重啟
2。服務(wù)器被更新
3。日志到達(dá)了最大日志長度 max_binlog_size
4。日志被刷新 mysql> flush logs;

工具介紹:
shell>>mysqlbinlog [option] binlogFile> newfile
如: D:\mysql\log>mysqlbinlog binlog.000001 > 1.txt
一個例子:
log-bin=”D:/mysql/log/binlog” 那么,在該文件夾下就會有文件D:/mysql/log/binlog.000001等

常見問題
1.如何清除binlog
>>>使用下面的兩個命令
PURGE {MASTER | BINARY} LOGS TO ‘log_name' //log_name不會被清除
PURGE {MASTER | BINARY} LOGS BEFORE ‘date' //date不會被清除

實例如下:
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開始

注:如果您有一個活性的從屬服務(wù)器,該服務(wù)器當(dāng)前正在讀取您正在試圖刪除的日志之一,
則本語句不會起作用,而是會失敗,并伴隨一個錯誤。
不過,如果從屬服務(wù)器是休止的,并且您碰巧清理了其想要讀取的日志之一,則從屬服務(wù)器啟動后不能復(fù)制。
當(dāng)從屬服務(wù)器正在復(fù)制時,本語句可以安全運行。您不需要停止它們。

2.記錄到二進(jìn)制日志知的內(nèi)容配置
binlog-do-db=sales 只記錄sales庫
binlog-ignore-db=sales 除sales庫不記錄,其他都記錄

但是如果在操作數(shù)據(jù)庫之前,不使用use $dbname 那么所有的SQL都不會記錄
如果使用了use $dbname,那么判斷規(guī)則取決于這里的$dbname,而不是SQL中操作的庫

3.二進(jìn)制日志不準(zhǔn)確的處理
默認(rèn)情況下,并不是每次寫入時都將二進(jìn)制日志與硬盤同步。因此如果操作系統(tǒng)或機(jī)器(不僅僅是MySQL服務(wù)器)崩潰,有可能二進(jìn)制日志中最后的語句丟失。
要想防止這種情況,你可以使用sync_binlog全局變量(1是最安全的值,但也是最慢的),使二進(jìn)制日志在每N次二進(jìn)制日志寫入后與硬盤同步。
即使sync_binlog設(shè)置為1,出現(xiàn)崩潰時,也有可能表內(nèi)容和二進(jìn)制日志內(nèi)容之間存在不一致性。

如果崩潰恢復(fù)時MySQL服務(wù)器發(fā)現(xiàn)二進(jìn)制日志變短了(即至少缺少一個成功提交的InnoDB事務(wù)),
如果sync_binlog =1并且硬盤/文件系統(tǒng)的確能根據(jù)需要進(jìn)行同步(有些不需要)則不會發(fā)生,則輸出錯誤消息 (“二進(jìn)制日志<名>比期望的要小”)。
在這種情況下,二進(jìn)制日志不準(zhǔn)確,復(fù)制應(yīng)從主服務(wù)器的數(shù)據(jù)快照開始。

相關(guān)文章

  • mysql存儲emoji表情報錯的處理方法【更改編碼為utf8mb4】

    mysql存儲emoji表情報錯的處理方法【更改編碼為utf8mb4】

    這篇文章主要介紹了mysql存儲emoji表情報錯的處理方法,較為詳細(xì)的分析了通過更改mysql編碼為utf8mb4解決存儲emoji表情報錯的相關(guān)操作技巧,需要的朋友可以參考下
    2018-07-07
  • mysql字段為NULL索引是否會失效實例詳解

    mysql字段為NULL索引是否會失效實例詳解

    有很多人對null值是否走索引感覺很疑惑,所以下面這篇文章主要給大家介紹了關(guān)于mysql字段為NULL索引是否會失效的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • 解決mysql錯誤:Subquery?returns?more?than?1?row問題

    解決mysql錯誤:Subquery?returns?more?than?1?row問題

    這篇文章主要介紹了解決mysql錯誤:Subquery?returns?more?than?1?row問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • MySQL8.0數(shù)據(jù)庫開窗函數(shù)圖文詳解

    MySQL8.0數(shù)據(jù)庫開窗函數(shù)圖文詳解

    開窗函數(shù)為將要被操作的行的集合定義一個窗口,它對一組值進(jìn)行操作,不需要使用GROUP BY子句對數(shù)據(jù)進(jìn)行分組,能夠在同一行中同時返回基礎(chǔ)行的列和聚合列,這篇文章主要給大家介紹了關(guān)于MySQL8.0數(shù)據(jù)庫開窗函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • MySQL 如何修改root用戶的密碼

    MySQL 如何修改root用戶的密碼

    這篇文章主要介紹了MySQL 如何修改root用戶的密碼,幫助大家更好的使用MySQL,不用擔(dān)心忘記密碼,感興趣的朋友可以了解下
    2020-09-09
  • 基于MYSQL中優(yōu)化的一些方法

    基于MYSQL中優(yōu)化的一些方法

    本篇文章是對MYSQL中優(yōu)化的一些方法進(jìn)行了詳細(xì)的介紹,需要的朋友參考下
    2013-05-05
  • MySQL安全設(shè)置圖文教程

    MySQL安全設(shè)置圖文教程

    MySQL安全設(shè)置,跟mssql差不多都是以普通用戶權(quán)限運行mysql。其它的也需要注意下。
    2011-01-01
  • 五分鐘帶你搞懂MySQL索引下推

    五分鐘帶你搞懂MySQL索引下推

    這篇文章主要介紹了Mysql的索引下推,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-09-09
  • MySQL如何使用授權(quán)命令grant

    MySQL如何使用授權(quán)命令grant

    這篇文章主要介紹了MySQL如何使用授權(quán)命令grant,文中示例代碼非常詳細(xì),幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • Mysql分庫分表之后主鍵處理的幾種方法

    Mysql分庫分表之后主鍵處理的幾種方法

    Mysql分庫分表之后,主鍵如何處理?本文主要介紹了Mysql分庫分表之后主鍵處理的幾種方法,具有一定的參考價值,感興趣的可以了解一下
    2022-02-02

最新評論