真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么理解mysql中的redolog

今天就跟大家聊聊有關(guān)怎么理解MySQL中的redo log,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,提供網(wǎng)站設(shè)計制作、成都網(wǎng)站設(shè)計,網(wǎng)頁設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務;可快速的進行網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,是專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

重做日志(redo log)

前言:之前一直弄不清楚 mysql 里面 bin log 和 innodb log 文件的區(qū)別,在腦子里面一直有個疑問 binlog 日志文件已經(jīng)可以用來進行
數(shù)據(jù)庫的日志備份恢復了,怎么又多了一個 redo log 文件了。相信也有很多人有這個疑惑,現(xiàn)在把整個過程文檔整理出來,希望對大家有所幫忙。

如果對 Oracle 很了解,那么在整個學習 innoDB log 的時候,可以把聯(lián)
機重做日志的那套理論套在學習 innoDB log 上面,幾乎是一樣的;


1、innodb log 的基礎(chǔ)知識
innodb log 顧名思義:即 innodb 存儲引擎產(chǎn)生的日志,也可以稱為
重做日志文件,默認在 innodb_data_home_dir 下面有兩個文件
ib_logfile0 和 ib_logfile1。MySQL 官方手冊中將這兩個文件叫文
InnoDB 存儲引擎的日志文件;

查看日志文件位置:
[root@rh65 ~]# cat /etc/my.cnf
# Uncomment the following if you are using InnoDB tables
#innodb_data_home_dir = /usr/local/mysql/data
#innodb_data_file_path = ibdata1:10M:autoextend
#innodb_log_group_home_dir = /usr/local/mysql/data
# You can set .._buffer_pool_size up to 50 - 80 %
# of RAM but beware of setting memory usage too high
#innodb_buffer_pool_size = 16M
#innodb_additional_mem_pool_size = 2M
# Set .._log_file_size to 25 % of buffer pool size
#innodb_log_file_size = 5M
#innodb_log_buffer_size = 8M
#innodb_flush_log_at_trx_commit = 1
#innodb_lock_wait_timeout = 50
[root@rh65 ~]# cd /usr/local/mysql/data/
[root@rh65 data]# ls -l
total 28732
-rw-rw---- 1 mysql mysql 18874368 Jun 10 16:52 ibdata1
-rw-rw---- 1 mysql mysql 5242880 Jun 10 16:52 ib_logfile0
-rw-rw---- 1 mysql mysql 5242880 Jun 10 16:52 ib_logfile1
drwxr-xr-x 5 mysql mysql 4096 Jun 19 14:12 mysql
drwx------ 2 mysql mysql 4096 Jun 10 16:52
performance_schema
drwxr-xr-x 2 mysql mysql 4096 Jun 10 16:18 test


innodb log 的作用:當 MySQL 的實例和介質(zhì)失敗的時候,Innodb存儲引擎就會使用 innodb log 文件進行恢復,保證數(shù)據(jù)庫的完整性;

innodb log 的寫原理:(請容許我再放下 InnoDB 的原理圖,并且建議把這張圖看到吐)


每個 InnDB 存儲引擎至少有 1 個重做日志文件組(group),每個文件組下至少有兩個重做日志文件,默認的為 ib_logfile0、ib_logfile1;
日志組中每個重做日志的大小一致,并循環(huán)使用;

InnoDB 存儲引擎先寫重做日志文件,當文件滿了的時候,會自動切換到日志文件 2,當重做日志文件 2 也寫滿時,會再切換到重做日
志文件 1;為了保證安全和性能,請設(shè)置每個重做日志文件設(shè)置鏡像,并分配到不同的磁盤上面;

(發(fā)現(xiàn)以上特性跟 ORACLE 的連接重做日志文件簡直是一樣的)


2、innodb log 的相關(guān)參數(shù)

運行腳本:show variables like 'innodb%log%'; 查看重做日志的相關(guān)參數(shù)
mysql> show variables like 'innodb%log%';

常用設(shè)置的參數(shù)有:
innodb_mirrored_log_groups 鏡像組的數(shù)量,默認為 1,沒有鏡像;
innodb_log_group_home_dir 日志組所在的路徑,默認為 data 的home 目錄;
innodb_log_files_in_group 日志組的數(shù)量,默認為 2;
innodb_log_file_size 日志組的大小,默認為 5M;
innodb_log_buffer_size 日志緩沖池的大小,圖上為 30M

3、參數(shù)的相關(guān)調(diào)優(yōu)
3.1 重做日志文件的大小設(shè)置跟 ORACLE 一樣,面臨的問題是相似的。

當 innodb log 設(shè)置過大的時候,可能會導致系統(tǒng)崩潰后恢復需要很長的時間;
當 innodb log 設(shè)置過小的時候,當一個事務產(chǎn)生大量的日志的時候,需要多次切換重做日志文件,會產(chǎn)生類似如下的報警;
130702 12:53:13 InnoDB: ERROR: the age of the last checkpoint
is 2863217109,
InnoDB: which exceeds the log group capacity 566222311.
InnoDB: If you are using big BLOB or TEXT rows, you must set the
InnoDB: combined size of log files at least 10 times bigger than the


4、重做日志與二進制日志的區(qū)別
4.1 記錄的范圍不同:二進制日志會記錄 MySQL 的所有存儲引擎的日志記錄(包括 InnoDB、MyISAM 等),而 InnoDB 存儲引擎的重做日志只會記錄其本身的事務日志。
4.2 記錄的內(nèi)容不同:二進制日志文件記錄的格式可以為STATEMENT 或者 ROW 也可以是 MIXED,其記錄的都是關(guān)于一個事務的具體操作內(nèi)容。
InnoDB 存儲引擎的重做日志文件記錄的關(guān)于每個頁的更改的物理情況。
4.3 寫入的時間也不同:二進制日志文件是在事務提交前進行記錄的,而在事務進行的過程中,不斷有重做日志條目被寫入到重做日志文件中。

看完上述內(nèi)容,你們對怎么理解mysql中的redo log有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。


網(wǎng)頁題目:怎么理解mysql中的redolog
本文鏈接:http://weahome.cn/article/ijdhgi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部