写在前面
 本系列文章基于5.7.12 版本讲述MySQL的新特性。从安装,文件结构,SQL ,优化 ,运维层面 复制,GITD等几个方面展开介绍5.7 的新特性和功能。同时也建议大家跟踪官方blog和官方文档,以尽快知悉其新的变化。前面写了一篇文章介绍 innodb 的特性,囿于相关知识点比较多 ,本文继续介绍5.7版本的innodb 新特性。
4.1 innodb buffer dump 功能增强     
      5.7.5 新增加innodb_buffer_pool_dump_pct参数,来控制每个innodb buffer中转储活跃使用的innodb buffer pages的比例。之前的版本默认值是100%,当触发转储的时候 会全量dump innodb buffer pool中的pages。如果启用新的参数比如40 ,每个innodb buffer pool instance中有100个 ,每次转储每个innodb buffer 实例中的40个pages。
    注意:当innodb发现innodb 后台io资源紧张时,会主动降低该参数设置的比例。

4.2 支持多线程刷脏页  
      MySQL 5.6.2版本中,MySQL将刷脏页的线程从master线程独立出来,5.7.4版本之后,MySQL系统支持多线程刷脏页,进程的数量由innodb_page_cleaners参数控制,该参数不能动态修改,最小值为1 ,最大值支持64,5.7.7以及之前默认值是1 ,5.7.8版本之后修改默认参数为4。当启用多线程刷脏也,系统将刷新innodb buffer instance脏页分配到各个空闲的刷脏页的线程上,如果设置的innodb_page_cleaners>innodb_buffer_pool_instances,系统会自动重置为innodb_buffer_pool_instances大小。

4.3 动态调整 innodb buffer size
    从5.7.5版本, MySQL支持在不重启系统的情况下动态调整innodb_buffer_pool_size。resize的过程是以chunk(每个chunk的大小默认为128M)的为单位迁移pages到新的内存空间,迁移进度可以通过Innodb_buffer_pool_resize_status 查看。记住整个resize的大小是以chunk为单位的。innodb_buffer_pool_chunk_size的大小,计算公式是innodb_buffer_pool_size / innodb_buffer_pool_instances,新调整的值必须是 innodb_buffer_pool_chunk_size*innodb_buffer_pool_instances的整数倍。如果不是整数倍,则系统则会调整值为大于两者乘积的最大值。 
例子

  1. mysql> SHOW STATUS WHERE Variable_name='InnoDB_buffer_pool_resize_status';
  2. +----------------------------------+----------------------------------------------------------------------+
  3. | Variable_name | Value |
  4. +----------------------------------+----------------------------------------------------------------------+
  5. | Innodb_buffer_pool_resize_status | Size did not change (old size = new size = 268435456. Nothing to do. |
  6. +----------------------------------+----------------------------------------------------------------------+
  7. 1 row in set (0.00 sec)
  8. mysql> set global innodb_buffer_pool_size=128*1024*1024;
  9. Query OK, 0 rows affected (0.00 sec)
  10. mysql> SHOW STATUS WHERE Variable_name='InnoDB_buffer_pool_resize_status';
  11. +----------------------------------+----------------------------------------------------+
  12. | Variable_name | Value |
  13. +----------------------------------+----------------------------------------------------+
  14. | Innodb_buffer_pool_resize_status | Completed resizing buffer pool at 160702 23:53:51. |
  15. +----------------------------------+----------------------------------------------------+
  16. 1 row in set (0.00 sec)
  17. mysql> set global innodb_buffer_pool_size=256*1024*1024;
  18. Query OK, 0 rows affected (0.00 sec)
  19. mysql> SHOW STATUS WHERE Variable_name='InnoDB_buffer_pool_resize_status';
  20. +----------------------------------+----------------------------------------------------+
  21. | Variable_name | Value |
  22. +----------------------------------+----------------------------------------------------+
  23. | Innodb_buffer_pool_resize_status | Completed resizing buffer pool at 160702 23:54:19. |
  24. +----------------------------------+----------------------------------------------------+
  25. 1 row in set (0.00 sec)

online调整bp size的log 记录大致过程 
a 计算要调整的bpsize
b 禁止AHI,清理所有的索引缓存
c Withdrawing block是遍历freelist 确定可以使用的空闲block
d 锁住整个buffer pool 
e 迁移重新分配chunk/删除可以释放的chunk 
f 设置innodb_buffer_pool_size为新的值
g 重新开启AHI

  1. 2016-07-02T15:40:44.724495Z 0 [Note] InnoDB: Resizing buffer pool from 134217728 to 268435456 (unit=134217728).
  2. 2016-07-02T15:40:44.724546Z 2 [Note] InnoDB: Resizing buffer pool from 134217 (new size: 268435456 bytes)
  3. 2016-07-02T15:40:44.724559Z 0 [Note] InnoDB: Disabling adaptive hash index.
  4. 2016-07-02T15:40:44.724979Z 0 [Note] InnoDB: disabled adaptive hash index.
  5. 2016-07-02T15:40:44.725029Z 0 [Note] InnoDB: Withdrawing blocks to be shrunken.
  6. 2016-07-02T15:40:44.725040Z 0 [Note] InnoDB: Latching whole of buffer pool.
  7. 2016-07-02T15:40:44.725210Z 0 [Note] InnoDB: buffer pool 0 : resizing with chunks 1 to 2.
  8. 2016-07-02T15:40:44.735439Z 0 [Note] InnoDB: buffer pool 0 : 1 chunks (8192 blocks) were added.
  9. 2016-07-02T15:40:44.735511Z 0 [Note] InnoDB: Completed to resize buffer pool from 134217728 to 268435456.
  10. 2016-07-02T15:40:44.735561Z 0 [Note] InnoDB: Re-enabled adaptive hash index.
  11. 2016-07-02T15:40:44.735586Z 0 [Note] InnoDB: Completed resizing buffer pool at 160702 23:40:44.

这个特性是最令众多MySQL DBA 期待的特性之一。以后线上动态扩容,缩容就无需做数据库切换了,间接增强了系统的稳定性和DBA的生活幸福感。当然本文中介绍的略显粗略。详细内容请参考《官方文档》

4.4 支持全局表空间 
     全局表空间可以被所有的数据库的表共享,而且相比于 file-per-table tablespaces. 使用共享表空间可以节约元数据方面的内存。(需要更深入的了解共享表空间 主要是大小 收缩问题)

  1. mysql> CREATE TABLESPACE `youzan_com`
  2. -> ADD DATAFILE 'youzan_com.ibd' FILE_BLOCK_SIZE = 16k;
  3. Query OK, 0 rows affected (0.02 sec)
  4. mysql> use yang
  5. Database changed
  6. mysql> create table yztb(id int primary key not null ,val char(10)) engine=innodb default charset=utf8 TABLESPACE youzan_com ;
  7. Query OK, 0 rows affected (0.04 sec)
  8. mysql> create database youzan default charset utf8;
  9. Query OK, 1 row affected (0.02 sec)
  10. mysql> use youzan
  11. Database changed
  12. mysql>
  13. mysql> create table yztb(id int primary key not null ,val char(10)) engine=innodb default charset=utf8 TABLESPACE youzan_com ;
  14. Query OK, 0 rows affected (0.03 sec)

4.5 行格式默认为DYNAMIC
     从MySQL 5.7.9 开始,行格式DYNAMIC 取代COMPACT 成为innodb存储引擎默认的行格式,MySQL提供了新的参数innodb_default_row_format来控制Innodb 行格式,详细的信息请参考《Specifying the Row Format for a Table

4.6 支持原生的分区表
      在MySQL 5.7.6之前的版本中,创建分区表时MySQL为每个分区创建一个ha_partition handler,自MySQL 5.7.6之后,MySQL支持原生的分区表并且只会为分区表创建一个partition-aware handler,这样的分区表功能增强节约分区表使用的内存。对于老版本创建的分区表在升级到新的版本之后怎么处理呢?莫慌,5.7.9之后,MySQL提供了如下升级方式解决这个问题:

  1. ALTER TABLE ... UPGRADE PARTITIONING.

当然友情提示:从我个人的理解来看,在没有合适的自动化维护分区表系统的基础上,不推荐使用分区表。四年的工作经历已经数次在分区表上掉坑里了。

4.7 支持truncate undo logs 
     MySQL 5.7.5版本开始支持truncate undo 表空间中的undo log。启用该特性必须设置innodb_undo_log_truncate=[ON|1]。大致原理是系统必须设置至少两个undo 表空间(初始化的时候设置 innodb_undo_tablespaces=2 ) 用于清理undo logs的切换。该特性的好处是 解决了 ibdata 文件一直增大的问题,减轻系统的空间使用。 详细信息参考《官方文档》

小结
     到这里 innodb 部分算是基本完成,但是依然有很多其他的特性需要"探索" ,自己在写《MySQL 5.7 新特性》系列文章的时候,或深入或简单阅读官方文档,深刻的感觉到5.7 有很多新的变化,同时也感到自己对于5.6版本的官方文档并未阅读透彻,并没有之前学习Oracle的时候的学习方式---官方文档是最好的教材。在这里仅以过来人 DBA 老司机的角度给MySQL DBA新人的建议 多阅读官方文档,胜过市面上99%的书籍。
    后面会继续探索MySQL 5.7 新特性。
参考文章
[1] 《MySQL 5.7 官方文档》
[2] 《MySQL 5.7 初探》
[3] 《MySQL 5.7新特性之一》
[4] 《MySQL 5.7新特性之二》
[5] 《MySQL 5.7新特性之三》

【MySQL】5.7新特性之四相关推荐

  1. MySQL 8.0新特性--CTE Recurive(二)

    上一篇介绍了CTE的基本用法,参考MySQL 8.0新特性--CTE(一),本篇再来介绍一下CTE Recurive递归. 1.什么是CTE Recurive? A recursive common ...

  2. mysql8.0创建属性,MySQL 8.0新特性 — 管理端口的使用简介

    前言 下面这个报错,相信大多数童鞋都遇见过:那么碰到这个问题,我们应该怎么办呢?在MySQL 5.7及之前版本,出现"too many connection"报错,超级用户root ...

  3. mysql3819错误,MySQL 8.0新特性 ― 检查性约束的使用简介

    前言 在MySQL 8.0版本中,引入了一个非常有用的新特性 ― 检查性约束,它可以提高对非法或不合理数据写入的控制能力:接下来我们就来详细了解一下. 检查性约束 创建.删除与查看 (1)可以在建表时 ...

  4. MySQL 5.7 新特性解读

    2015年10月22日,MySQL发布5.7.9稳定版,虽然MySQL官方手册里已经有很多关于MySQL 5.7新特性的介绍,在这里,还是让我们一起看看在MySQL 5.7里有哪些值得我们关注的新特性 ...

  5. 【MySQL】MySQL 5.7 新特性整理

    MySQL 5.7 新特性有很多,有以下这些 一.InnoDB变更 默认存储引擎改为InnoDB:MySQL 5.7将默认存储引擎改为InnoDB,以推动其成为事实标准.这意味着任何未指定存储引擎的表 ...

  6. MySQL 8.0 新特性:引人注目的哈希连接(Hash Join)

    点击上方"朱小厮的博客",选择"设为星标" 后台回复"书",获取 来源:r6d.cn/uATq MySQL 开发组于 2019 年 10 月 ...

  7. sql server的密码采用自带什么密码技术存储_【技术分享】浅谈MYSQL 8.0新特性

    于树文 云技术管理处 01 MySQL 8.0中添加的功能 1. 新的系统字典表 整合了存储有关数据库对象信息的事务数据字典,所有的元数据都用InnoDB引擎进行存储. 2. 支持DDL 原子操作 I ...

  8. mysql+8.0+新特性_MySQL 8.0备受瞩目的新特性大放送!

    原标题:MySQL 8.0备受瞩目的新特性大放送! 作者介绍 杨奇龙,目前就职于有赞科技,负责数据库运维工作,熟悉MySQL性能优化.故障诊断.性能压测. MySQL于 2016-09-12正式发布8 ...

  9. MySQL 5.0 新特性教程 触发器:第一讲

    滥觞:网海拾贝 作者:mysql AB;翻译:陈朋奕 Conventions and Styles约定和编程作风 每次我想要演示实践代码时,我会对mysql客户真个屏幕就出现的代码阻止调解排解,将字体 ...

  10. mysql 6.0 新特性 2014_MySQL 各版本的特性

    Mysql5.5 特性,相对于Mysql5.1 性能提升 默认存储引擎更改为 InnoDB引擎.具有提交.回滚和宕机恢复功能 和ACID兼容. 行级锁. 表与索引存储在表空间中, 表大小无限制. 支持 ...

最新文章

  1. 粉丝们请注意!送款全新的AirPods Pro!
  2. 管理员信息管理之保存管理员数据
  3. linux NFS配置:NFS相关概念及其配置与查看
  4. PV(page view)
  5. Ubuntu14.04下安装wineqq国际版和卸载QQ
  6. Bootstrap 5款常用模板
  7. 【转】如何打包发布基于Qt4 Windows的软件
  8. android studio进度条的应用,Android Studio实现进度条效果
  9. 本地chrome调试服务器node
  10. Kurento Tree 简介
  11. (转)微服务架构的理论基础 - 康威定律
  12. RestSharp的使用记录
  13. 数据库 ER图、关系模式相互转换 关系代数表达式 查询树,优化查询树 SQL题目
  14. Web自动化测试之playwright:设置浏览器语言
  15. 根据经纬度获取地址(逆地址解析)
  16. 基于OAS设计可扩展OpenAPI
  17. UIImageView绘制圆形图片
  18. 把多个txt文档合并为一个txt文档并排序
  19. learnpythonthehardway下载_只需十四步:从零开始掌握Python机器学习(附资源)
  20. oracle分页语句解释,oracle分页语句

热门文章

  1. 筛选DataTable数据的方法
  2. iphone 推送服务--Apple Push Notification Service
  3. JS计算GridView里的TextBox
  4. Qt常用类——Qpoint
  5. 【winfrom】Excel文件加载
  6. Linux SendMail发送邮件失败诊断案例(四)
  7. 一些会遗忘的代码属性
  8. 日更第4期-2015-1-19-openFrameworks系列第三讲-面向对象的小球们
  9. Erlang实战练习(一)
  10. CSS实现文字竖排效果