zoukankan      html  css  js  c++  java
  • MySQL 重做日志文件

    一、innodb log的基础知识

    · innodb log顾名思义:即innodb存储引擎产生的日志,也可以称为重做日志文件,默认在innodb_data_home_dir下面有两个文件ib_logfile0和ib_logfile1。MySQL官方手册中将这两个文件叫文InnoDB存储引擎的日志文件;

    · innodb log的作用:当MySQL的实例和介质失败的时候,Innodb存储引擎就会使用innodb log文件进行恢复,保证数据库的完整性;

    · innodb log的写原理:(请容许我再放下InnoDB的原理图,并且建议把这张图看到吐)

    看红色框框的那部分

    wps5B8.tmp

    · 每个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%';

    wps5B9.tmp

    常用设置的参数有:

    innodb_mirrored_log_groups  镜像组的数量,默认为1,没有镜像;

    innodb_log_group_home_dir  日志组所在的路径,默认为data的home目录;

    innodb_log_files_in_group    日志组的数量,默认为2;

    innodb_log_file_size              日志组的大小,默认为5M;

    innodb_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 the

    InnoDB: 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 写入的时间也不同:二进制日志文件是在事务提交前进行记录的,而在事务进行的过程中,不断有重做日志条目被写入到重做日志文件中。

  • 相关阅读:
    Spark学习(一)Spark初识
    service mysqld restart mysqld: 未被识别的服务
    Spark学习(二)Spark 版本 WordCount
    java.sql.SQLException: Incorrect string value: '\xE4\xB8\xAD\xE9\x83\xA8' for column 'area' at row 1
    centos 6.8 yum源不可用安装报YumRepo Error: All mirror URLs are not using ftp, http[s] or file
    互联网运维装腔指南
    PHP生成一段时间之间的月份列表
    sql根据分组后排序取第一条数据
    sql 多行拼接 成一行
    js 常用汇总
  • 原文地址:https://www.cnblogs.com/wcwen1990/p/6655395.html
Copyright © 2011-2022 走看看