mysql innodb学习(二)

以前的一篇简单介绍了innodb_buffer_pool_size的做用,下面接下来和你们分享一下innodb的日志文件相关的参数的做用。mysql

  • innodb_log_file_size 这个值定义了日志文件的大小,innodb日志文件的做用是用来保存redo日志。一个事务对于数据或索引的修改每每对应到表空间中的随机的位置,所以当刷新这些修改到磁盘中就会引发随机的I/O,而随机的I/O每每比顺序的I/O更加昂贵的开销,由于随机的I/O须要更多的开销来定位到指定的位置。

innodb使用日志来将随机的I/O转为顺序的I/O,只要日志文件是安全的,那么事务就是永久的,尽管这些改变尚未写到数据文件中,若是出现了当机或服务器断电的状况,那么innodb也能够经过日志文件来恢复以及提交的事务。可是日志文件是有必定的大小的,因此必需要把日志文件记录的改变写到数据文件中,innodb对于日志文件的操做是循环的,即当日志文件写满后,会将指针从新移动到文件开始的地方从新写,可是它不会覆盖那些尚未写到数据文件中的日志,由于这是惟一记录了事务持久化的记录。sql

innodb使用一个后台的线程来刷新日志中的记录到数据文件中,这个线程能够合并写操做来使之变成顺序I/O来提升效率。innodb能够设置多个日志文件,而日志文件的总的大小就是全部日志文件加起来的总大小,而innodb对这些日志文件的处理至关于一个日志文件,使用循环的方式来操做,就是当一个日志文件写满之后,才会将后续的记录写到下一个日志文件,当全部的日志文件都写满后,innodb就会从头开始写。mysql中默认的日志文件为2个5M的文件,这对于压力大的状况下是远远不够的,那咱们怎么样来修改日志文件的大小呢?在重启mysql服务以前,首先将日志文件删除,而后修改配置文件中的日志文件的大小,而后执行重启的操做,在重启的过程当中,mysql会从新建立指定大小的日志文件。缓存

innodb的日志文件也是保存在磁盘中的,那写的速度也是相对慢的,innodb中使用了日志缓存来提升写的速度。innodb会将全部的日志首先写到日志缓存中,而后再经过后台的一个线程将这这些缓存刷新到磁盘的日志文件中。那么innodb是在何时才将缓存刷新到日志文件的呢? innodb中有一个配置参数来控制这个行为,innodb_flush_log_at_trx_commit,这个参数能够设置为3个不一样的值:安全

  • 0 在事务提交时不执行任何操做,innodb的后台线程会每秒执行一次刷新操做服务器

  • 1 事务的每一次提交,innodb都会将日志缓存中的数据刷新到日志文件(这是mysql对innodb默认的设置,也是最安全的设置)操作系统

  • 2 事务的每一次提交,innodb都会把日志缓存中的数据刷新到磁盘,可是不执行flush的操做(即只写到操做系统的缓存中),这个值跟0的区别为,这个操做在服务崩溃会其余异常状况下不会丢失任何的事务线程

可是还有一个问题就是innodb如何将日志缓存刷新到日志文件?这个问题将在接下来的文章中跟你们分享。指针

相关文章
相关标签/搜索