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

MySQL中二進(jìn)制與重做日志文件的基本概念學(xué)習(xí)教程

 更新時(shí)間:2015年11月24日 10:09:43   作者:一寧  
這篇文章主要介紹了MySQL中二進(jìn)制日志文件與重做日志文件的基本概念學(xué)習(xí)教程,講到了一些重做日志與二進(jìn)制日志的區(qū)別,需要的朋友可以參考下

二進(jìn)制日志
二進(jìn)制日志記錄了所有對(duì)數(shù)據(jù)庫(kù)執(zhí)行更改的操作,二進(jìn)制主要有以下兩種作用:

1、恢復(fù)(recovery)2、復(fù)制(replication)

二進(jìn)制日志的啟動(dòng):配置參數(shù)log-bin[=name],如果不指定name,則默認(rèn)二進(jìn)制日志文件名為主機(jī)名,后綴名為二級(jí)制日志的序列號(hào),所在路徑為數(shù)據(jù)庫(kù)所在目錄。

以index為后綴的文件為二進(jìn)制日志的索引文件,用來(lái)存儲(chǔ)過(guò)往生產(chǎn)的二進(jìn)制日志。

和二進(jìn)制日志相關(guān)的參數(shù):

max_binlog_size、binlog_cache_size、sync_binlog、binlog-do-db、binlog-ignore-db、log-slave-update、binlog_format

max_binlog_size,該參數(shù)指定了單個(gè)二進(jìn)制日志文件的最大值,如果超過(guò)該值,則產(chǎn)生新的二進(jìn)制日志文件,后綴名+1,并記錄到.index文件,從Mysql5.0開始的默認(rèn)值為1073741824,代表1G。

Mysql5.5的默認(rèn)值

20151124100730266.png (462×152)

當(dāng)使用事務(wù)的存儲(chǔ)引擎InnoDB時(shí),所有未提交的事務(wù)會(huì)記錄到一個(gè)緩存中,等待事務(wù)提交時(shí),直接將緩沖中的二進(jìn)制日志寫入二進(jìn)制日志文件,而該緩沖的大小由binlog_cache_size決定,默認(rèn)大小為32KB,此外,binlog_cache_size是基于回話的,也就是,當(dāng)一個(gè)線程開始一個(gè)事務(wù)時(shí),mysql會(huì)自動(dòng)分配一個(gè)大小為binlog_cache_size的緩存,因此該值得設(shè)置需要相當(dāng)小心,可以通過(guò)show global status 查看binlog_cache_use、binlog_cache_disk_use的狀態(tài),可以判斷當(dāng)前binlog_cache_size的設(shè)置是否合適。

Binlog_cache_size的默認(rèn)大小為32KB

20151124100751510.png (365×121)

參數(shù)sync_binlog=[N]表示每寫緩存多少次就同步到磁盤,如果將N設(shè)置為1,則表示采用同步寫磁盤的方式來(lái)寫二進(jìn)制日志,該參數(shù)很重要,這個(gè)以后還會(huì)提到。值得注意的是,在將該參數(shù)設(shè)置為1時(shí),也應(yīng)該將innodb_support_xa設(shè)為1來(lái)解決,這可以確保二進(jìn)制日志和InnoDB存儲(chǔ)引擎數(shù)據(jù)文件的同步。

參數(shù)binlog-do-db和binlog-ignore-db表示需要寫入或者忽略寫入哪些庫(kù)的日志,默認(rèn)值為空,則表示將所有庫(kù)的日志同步到二進(jìn)制日志。

Log-slave-update該參數(shù)在搭建master=>slave=>slave的架構(gòu)時(shí),需要配置。

Binlog_format參數(shù)也特別重要。從mysql5.1版本開始引入這個(gè)參數(shù),該參數(shù)可以設(shè)置的值有STATEMENT\、ROW、MIXED;

(1)STATEMENT格式和之前的mysql版本一樣,二進(jìn)制日志文件記錄的是日志的邏輯失SQL語(yǔ)句。

(2)在ROW格式下,二進(jìn)制日志記錄的不再是簡(jiǎn)單的SQL語(yǔ)句了,而是記錄表的行更改情況,此時(shí)可以將InnoDB的事務(wù)隔離基本設(shè)為READ COMMITTED,以獲得更好的并發(fā)性。

(3)MIXED格式下,mysql默認(rèn)采用的STATEMENT格式進(jìn)行二進(jìn)制日志文件的記錄,但是在一些情況下會(huì)使用ROW格式,可能的情況包括:

1)表的存儲(chǔ)引擎為NDB,這時(shí)對(duì)于表的DML操作都會(huì)以ROW格式記錄

2)使用了UUID()、USER()、CURRENT_USER()、FOUND_ROWS()、ROW_COUNT()等不確定函數(shù)

3)使用了INSERT DELAY語(yǔ)句

4)使用了用戶定義函數(shù)

5)使用了臨時(shí)表

重做日志
Mysql默認(rèn)情況下會(huì)有兩個(gè)文件:ib_logfile0和ib_logfile1,這兩個(gè)文件就是重做日志文件,或者事務(wù)日志。

重做日志的目的:萬(wàn)一實(shí)例或者介質(zhì)失敗,重做日志文件就能派上用場(chǎng)。

每個(gè)InnoDB存儲(chǔ)引擎至少有一個(gè)重做日志文件組,每個(gè)文件組下至少有2個(gè)重做日志文件,如默認(rèn)的ib_logfile0、ib_logfile1。InnoDB存儲(chǔ)引擎先寫重做日志文件1,當(dāng)達(dá)到文件的最后時(shí),會(huì)切換至重做日志文件2,當(dāng)重做日志文件2也被寫滿時(shí),會(huì)再被切換到重做日志文件1中。

影響重做日志的參數(shù):

Innodb_log_file_size、innodb_log_files_in_group、innodb_log_group_home_dir影響著重做日志文件的屬性。

20151124100900352.png (695×286)

重做日志與二進(jìn)制日志的區(qū)別:

1)二進(jìn)制日志會(huì)記錄所有與mysql有關(guān)的日志記錄,包括InnoDB等其他存儲(chǔ)引擎的日志,而InnoDB存儲(chǔ)引擎的重做日志只記錄有關(guān)其本身的事務(wù)日志,

2)記錄的內(nèi)容不容,不管你將二進(jìn)制日志文件記錄的格式設(shè)為哪一種,其記錄的都是關(guān)于一個(gè)事務(wù)的具體操作內(nèi)容,而InnoDB存儲(chǔ)引擎的重做日志文件記錄的關(guān)于每個(gè)頁(yè)的更改的物理情況;

3)寫入的時(shí)間也不同,二進(jìn)制日志文件是在事務(wù)提交前進(jìn)行記錄的,而在事務(wù)進(jìn)行的過(guò)程中,不斷有重做日志條目被寫入重做日志文件中。

從日志緩沖寫入磁盤上的重做日志文件的條件:

在主線程中每秒會(huì)將重做日志緩沖寫入磁盤的重做日志文件中,不論事務(wù)是否提交。另一個(gè)觸發(fā)這個(gè)過(guò)程是由參數(shù)innodb_flush_log_at_trx_commit控制,表示在提交時(shí),處理重做日志的方式。

參數(shù)innodb_flush_log_at_trx_commit可設(shè)的值有0、1、2,0代表當(dāng)提交事務(wù)時(shí),并不將事務(wù)的重做日志寫入磁盤上的日志文件,而是等待主線程每秒的刷新,而1和2不同的地方在于:1是在commit時(shí)將重做日志緩沖同步寫到磁盤;2是重做日志異步寫到磁盤,即不能完全保證commit時(shí)肯定會(huì)寫入重做日志文件,只是有這個(gè)動(dòng)作。

 值得注意的一點(diǎn):因?yàn)橹刈鋈罩居袀€(gè)capacity變量,該值代表了最后的檢查點(diǎn)不能超過(guò)這個(gè)閥值。

相關(guān)文章

  • MySQL 查詢結(jié)果取交集的實(shí)現(xiàn)方法

    MySQL 查詢結(jié)果取交集的實(shí)現(xiàn)方法

    本文將詳細(xì)介紹MySQL中如何實(shí)現(xiàn)以SQL查詢返回的結(jié)果集取交集的實(shí)現(xiàn)方法,需要的朋友可以參考
    2012-11-11
  • Mysql中時(shí)間戳轉(zhuǎn)為Date的方法示例

    Mysql中時(shí)間戳轉(zhuǎn)為Date的方法示例

    這篇文章主要給大家介紹了關(guān)于Mysql中時(shí)間戳轉(zhuǎn)為Date的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • MYSQL鎖表問(wèn)題的解決方法

    MYSQL鎖表問(wèn)題的解決方法

    這篇文章主要介紹了MYSQL鎖表問(wèn)題的解決方法,結(jié)合實(shí)例形式分析了MySQL鎖表問(wèn)題的常見情況與相應(yīng)解決方法,需要的朋友可以參考下
    2016-03-03
  • Mysql中返回一個(gè)數(shù)據(jù)庫(kù)的所有表名,列名數(shù)據(jù)類型備注

    Mysql中返回一個(gè)數(shù)據(jù)庫(kù)的所有表名,列名數(shù)據(jù)類型備注

    在Mysql中怎樣返回一個(gè)數(shù)據(jù)庫(kù)的所有表名,列名數(shù)據(jù)類型備注
    2010-04-04
  • MySQL常用表級(jí)操作總結(jié)

    MySQL常用表級(jí)操作總結(jié)

    這篇文章主要為大家詳細(xì)介紹了MySQL中常用的表級(jí)操作,文中的示例代碼簡(jiǎn)潔易懂,對(duì)我們學(xué)習(xí)MySQL有一定的幫助,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-08-08
  • 淺談Mysql指定順序排序查詢

    淺談Mysql指定順序排序查詢

    給大家用過(guò)實(shí)例分析了Mysql查詢中指定順序排序的相關(guān)技術(shù)問(wèn)題,需要的朋友參考一下吧。
    2017-12-12
  • MySQL新建用戶中的%到底包不包括localhost?

    MySQL新建用戶中的%到底包不包括localhost?

    操作MySQL的時(shí)候發(fā)現(xiàn),有時(shí)只建了%的賬號(hào),可以通過(guò)localhost連接,有時(shí)候卻不可以,網(wǎng)上搜索也找不到滿意的答案,干脆手動(dòng)測(cè)試一波
    2019-02-02
  • MySQL在線開啟或禁用GTID模式

    MySQL在線開啟或禁用GTID模式

    本文詳細(xì)講解了MySQL在線開啟或禁用GTID模式的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-11-11
  • MySql如何去除字符串前綴,兩邊,后綴

    MySql如何去除字符串前綴,兩邊,后綴

    這篇文章主要介紹了MySql如何去除字符串前綴,兩邊,后綴,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • MySQL給新建用戶并賦予權(quán)限最簡(jiǎn)單的方法

    MySQL給新建用戶并賦予權(quán)限最簡(jiǎn)單的方法

    在本篇文章里小編給大家整理的是一篇關(guān)于MySQL給新建用戶并賦予權(quán)限最簡(jiǎn)單的方法,需要的朋友們參考下。
    2019-11-11

最新評(píng)論