redo和undo

基本知识普及:

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表示日志缓冲被写到文件,但不对日志文件做到磁盘操作的刷新,也就是说重做日志同步到磁盘是异步的。

重做日志文件的大小,不能设置得太大,很大在恢复时可能需要很长的时间;也不能太小,否则可能导致一个事务的日志需要多次切换重做日志文件。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值