基本知识普及:
redo log重做日志 ,默认在ib_logfile0、 ib_logfile1,
undo log撤消日志,在共享表空间中,
重做日志:每次事务提交时候,会先将更改操作记录到redo log,这样当宕机或其他事故,可以用于恢复,继续执行未执行完的事务。
撤消日志:主要用于回滚,还用来实现多版本控制(MVCC).
重做日志
默认有两个文件,ib_logfile0和ib_logfile1
重做日志文件的主要目的是,如果数据库由于所在主机掉电导致实例失败,InnoDB存储引擎会使用重做日志恢复到掉电前的时刻,以此来保证数据的完整性。
每个InnoDB至少有1个重做日志文件组(group),每个文件组下至少有2个重做日志文件,如默认的ib_logfile0、ib_logfile1
可以设置多个镜像日志组(mirrored log groups),将不同的文件组放在不同的磁盘上。日志组中每个重做日志文件的大小一致,并以循环方式使用。InnoDB存储引擎先写重做日志文件0,当写满时,会切换至重做日志文件1,当1也被写满时,会再切换到0中。
innodb_log_file_size 重做日志文件大小;
innodb_log_files_in_group 日志文件组中重做日志文件的数量,默认为2;
innodb_mirrored_log_groups 日志镜像文件组的数量,默认为1,代表只有一个日志文件组,没有镜像;
innodb_log_group_home_dir 日志文件组所在路径,默认在数据库路径下。
innodb_flush_log_at_trx_commit 值有0,1,2。
0表示日志缓冲每秒一次地被写到日志文件,并且对日志文件做到磁盘操作的刷新,但是在一个事务提交不做任何操作。
1(默认)表示每次事务提交时,日志缓冲被写到日志文件,对日志文件做到磁盘操作的刷新。
2表示日志缓冲被写到文件,但不对日志文件做到磁盘操作的刷新,也就是说重做日志同步到磁盘是异步的。
重做日志文件的大小,不能设置得太大,很大在恢复时可能需要很长的时间;也不能太小,否则可能导致一个事务的日志需要多次切换重做日志文件。