网站开发项目团队人员,林壑地板北京网站建设,竞价排名深度解析,恢复原来的百度前言:之前一直弄不清楚mysql里面bin log和innodb log文件的区别#xff0c;在脑子里面一直有个疑问binlog日志文件已经可以用来进行数据库的日志备份恢复了#xff0c;怎么又多了一个redo log文件了。相信也有很多人有这个疑惑#xff0c;现在把整个过程文档整理出来#x…前言:之前一直弄不清楚mysql里面bin log和innodb log文件的区别在脑子里面一直有个疑问binlog日志文件已经可以用来进行数据库的日志备份恢复了怎么又多了一个redo log文件了。相信也有很多人有这个疑惑现在把整个过程文档整理出来希望对大家有所帮忙。如果对Oracle很了解,那么在整个学习innoDB log的时候,可以把联机重做日志的那套理论套在学习innoDB log上面,几乎是一样的;一、innodb log的基础知识innodb log顾名思义即innodb存储引擎产生的日志也可以称为重做日志文件默认在innodb_data_home_dir下面有两个文件ib_logfile0和ib_logfile1。MySQL官方手册中将这两个文件叫文InnoDB存储引擎的日志文件innodb log的作用当MySQL的实例和介质失败的时候Innodb存储引擎就会使用innodb log文件进行恢复保证数据库的完整性innodb log的写原理(请容许我再放下InnoDB的原理图并且建议把这张图看到吐)看红色框框的那部分每个InnDB存储引擎至少有1个重做日志文件组(group)每个文件组下至少有两个重做日志文件默认的为ib_logfile0、ib_logfile1日志组中每个重做日志的大小一致并循环使用InnoDB存储引擎先写重做日志文件当文件满了的时候会自动切换到日志文件2当重做日志文件2也写满时会再切换到重做日志文件1为了保证安全和性能请设置每个重做日志文件设置镜像并分配到不同的磁盘上面(发现以上特性跟ORACLE的连接重做日志文件简直是一样的)二、innodb log的相关参数运行脚本show variables like innodb%log%; 查看重做日志的相关参数mysql show variables like innodb%log%;常用设置的参数有innodb_mirrored_log_groups 镜像组的数量默认为1没有镜像innodb_log_group_home_dir 日志组所在的路径默认为data的home目录innodb_log_files_in_group 日志组的数量默认为2innodb_log_file_size 日志组的大小,默认为5Minnodb_log_buffer_size 日志缓冲池的大小图上为30M;三、参数的相关调优3.1 重做日志文件的大小设置跟ORACLE一样面临的问题是相似的。当innodb log设置过大的时候可能会导致系统崩溃后恢复需要很长的时间当innodb log设置过小的时候当一个事务产生大量的日志的时候需要多次切换重做日志文件会产生类似如下的报警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 theInnoDB: combined size of log files at least 10 times bigger than the四、重做日志与二进制日志的区别4.1 记录的范围不同二进制日志会记录MySQL的所有存储引擎的日志记录(包括InnoDB、MyISAM等)而InnoDB存储引擎的重做日志只会记录其本身的事务日志。4.2 记录的内容不同二进制日志文件记录的格式可以为STATEMENT或者ROW也可以是MIXED其记录的都是关于一个事务的具体操作内容。InnoDB存储引擎的重做日志文件记录的关于每个页的更改的物理情况。4.3 写入的时间也不同二进制日志文件是在事务提交前进行记录的而在事务进行的过程中不断有重做日志条目被写入到重做日志文件中。总结理论指导实践理论的知识虽然比较枯燥学习跟建房子一样看着很漂亮的高楼大厦地下往往要有一个坚实的基础基础打好了高楼也能建得稳了。