MySQL innodb_undo_tablespaces相关参数

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

摘录自:http://gfsunny.blog.51cto.com/990565/1566683

 

undo log(回滚): 服务器异常关机或断电重启后,MySQL会对修改过,但尚未提交的事务进行回滚。

 

MySQL5.6中开始支持把undo log分离到独立的表空间,并放到单独的文件目录下。这给部署不同IO类型的文件位置带来便利,对于并发写入型负载,可以把undo文件部署到单独的高速SSD存储设备上

 

undo tablespaces相关参数

参数 含义
innodb_undo_directory[=/opt/mysql/undo] Innodb为还原日志创建的独立表空间的相对或绝对路径。通常用于日志被放置在哪些不同的存储设备上。配合参数innodb_undo_logsinnodb_undo_tablespaces,这决定了系统表空间外还原日志的磁盘分布。默认目录为innodb默认创建它的其他日志文件的目录。

如果想转移undo文件的位置,只需要修改下该配置,并将undo文件拷贝过去就可以了。

【支持后期修改】
innodb_undo_logs[=128]

定义在一个事务中innodb使用的系统表空间中回滚段的个数。如果观察到同回滚日志有关的互斥争用,可以调整这个参数以优化性能早期版本的命名为innodb_rollback_segments,该变量可以动态调整,但是物理上的回滚段不会减少,只是会控制用到的回滚段的个数;默认为128个回滚段【手册上最大就是128

【支持后期修改】
innodb_undo_tablespaces[=4]

用于设定创建的undo表空间的个数,mysql_install_db时初始化后,就再也不能被改动了,修改该值会导致MySQL无法启动

默认值为0,表示不独立设置undotablespace,默认记录到ibdata中;否则,则在undo目录下创建这么多个undo文件(每个文件的默认大小为10M)。最多可以设置到126

例如假定设置该值为4,那么就会在mysqldata目录下创建命名为undo001~undo004undo tablespace文件。

【不支持后期修改】


undo 回滚段初始化

如果是正常shutdown重启,并且设置的回滚段个数大于目前已经使用的回滚段个数(trx_sysf_rseg_find_free),就会去新建回滚段(trx_rseg_create)

 

这里总是从第一个undologtablespace开始初始化回滚段,看起来似乎有些问题,极端情况下,如果我每次重启递增innodb_undo_logs,是不是意味着所有的undo回滚段都会写入到第一个undo tablespace?

 

完成初始化后,将当前可用的undo回滚段的个数复制给srv_available_undo_logs,可以通过show status查看:

mysql> show status like'innodb_available_undo_logs';

+----------------------------+-------+

| Variable_name              | Value |

+----------------------------+-------+

| Innodb_available_undo_logs | 128   |

+----------------------------+-------+

1 row in set (0.02 sec)

启动后,innodb_undo_logs是可以动态调整的,但最大不可以超过Innodb_available_undo_logs


在一个非只读的事务开启时,会为其分配回滚段(trx_assign_rseg_low),动态的调整innodb_undo_logs可以限定分配的回滚段范围;

当有长时间运行的事务时,可能导致purge操作来不及回收undo空间,进而导致undo空间急剧膨胀;理论上讲,如果做一次干净的shutdown,应该可以安全的将将这些undo文件删除并重新做一次初始化;也许未来的某个MySQL版本可能实现这个功能,这对于某些服务(比如按磁盘空间收费的云计算提供商)是非常有必要的功能。


参数设置演示:

# rm -rf /data/3306/data/*

# cd /usr/local/mysql/scripts/

# ./mysql_install_db--basedir=/usr/local/mysql --datadir=/data/3306/data --user=mysql --innodb_undo_tablespaces=4

# /etc/init.d/mysqld_3306start

 

注意:加了--innodb_undo_tablespaces=4参数初始化后,修改my.cnf,加入innodb_undo的参数,如下3行:

innodb_undo_logs=100

innodb_undo_tablespaces = 4

innodb_undo_directory = /tmp/  # 这里我是演示起见,随便设置的一个目录

启动mysql,在/tmp/目录下会生成独立的undo表空间文件,如下图:

wKiom1eIX9-SU5DDAAAxUMBsQds534.png

> show variables like 'innodb_undo%'; 也可以看到修改生效了

wKioL1eIX-jzre_lAAAfcWlkJKQ885.png


MySQL5.6手册上的截图如下:

wKiom1eIYBLihbvOAACt-mP_9DE512.png

wKiom1eIYBORWCQ9AACbXm1nkBk676.png

wKioL1eIYBODm-C7AAC8BKFj5wY873.png










本文转自 lirulei90 51CTO博客,原文链接:http://blog.51cto.com/lee90/1826658,如需转载请自行联系原作者
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
存储 关系型数据库 MySQL
MySQL InnoDB数据存储结构
MySQL InnoDB数据存储结构
|
1月前
|
存储 缓存 关系型数据库
MySQL的varchar水真的太深了——InnoDB记录存储结构
varchar(M) 能存多少个字符,为什么提示最大16383?innodb怎么知道varchar真正有多长?记录为NULL,innodb如何处理?某个列数据占用的字节数非常多怎么办?影响每行实际可用空间的因素有哪些?本篇围绕innodb默认行格式dynamic来说说原理。
829 6
MySQL的varchar水真的太深了——InnoDB记录存储结构
|
1月前
|
SQL 缓存 关系型数据库
Mysql第十四天,Mysql并发参数调整
Mysql第十四天,Mysql并发参数调整
29 0
|
2月前
|
存储 缓存 关系型数据库
MySQL - 存储引擎MyISAM和Innodb
MySQL - 存储引擎MyISAM和Innodb
|
12天前
|
存储 关系型数据库 MySQL
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
28 0
|
19天前
|
缓存 关系型数据库 MySQL
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
MySQL查询优化:提速查询效率的13大秘籍(合理使用索引合并、优化配置参数、使用分区优化性能、避免不必要的排序和group by操作)(下)
|
1月前
|
SQL 关系型数据库 MySQL
【Mysql】MYSQL参数max_allowed_packet 介绍
【Mysql】MYSQL参数max_allowed_packet 介绍
70 0
|
2月前
|
存储 SQL 关系型数据库
Mysql专栏 - mysql、innodb存储引擎、binlog的工作流程
Mysql专栏 - mysql、innodb存储引擎、binlog的工作流程
75 0
|
3月前
|
存储 算法 关系型数据库
MySQL相关(八)- innodb行级锁深入剖析
MySQL相关(八)- innodb行级锁深入剖析
45 0
|
3月前
|
存储 算法 关系型数据库
MySQL相关(七)- innodb 锁的介绍及使用
MySQL相关(七)- innodb 锁的介绍及使用
28 0