5.7 与 8

李欣桐2022年6月27日大约 5 分钟

MySql 5.7 和 MySql 8 的区别

  1. NoSql 存储

    Mysql 从 5.7 版本提供了 NoSQL 的存储功能,在 8.0 中这部分得到一些修改。

    • 关系型数据库 (SQL) 通过外键关联来建立表与表之间的关系

    • 非关系型数据库 (NOSQL) 通常指数据以对象的形式存储在数据库中,而对象之间的关系通过每个对象自身的属性来决定

  2. 隐藏索引

    隐藏索引的特性对于性能调试非常有用,在 8.0 中,索引可以被隐藏和显示,当一个索引隐藏时,他不会被查询优化器所使用

    也就是说可以隐藏一个索引,然后观察对数据库的影响.如果性能下降,就说明这个索引是有效的,于是将其”恢复显示”即可;如果数据库性能看不出变化,说明这个索引是多于的,可以删掉了

  3. 设置持久化

    MySQL 的设置可以在运行时通过 SET GLOBAL 命令来更改,但是这种更改只会临时生效,到下次启动时数据库又会从配置文件中读取。

    MySQL 8.0 新增了 SET PERSIST 命令, 例如: SET PERSIST max_connections = 500; MySQL 会将该命令的配置保存到数据目录下的 mysqld-auto.cnf 文件中,下次启动时会读取该文件,用其中的配置来覆盖缺省的配置文件。

  4. UTF-8 编码

    从 MySQL 8.0 开始,数据库的缺省编码将改为 utf8mb4,这个编码包含了所有 emoji 字符。 多少年来我们使用 MySQL 都要在编码方面小心翼翼,生怕忘了将缺省的 latin 改掉而出现乱码问题。从此以后就不用担心了。

  5. 通用表表达式 (Common Table Expressions)

    看上去层次和区域都更加分明,改起来也更清晰的知道要改哪一部分。

  6. 窗口函数 (Window Functions)

    从 8.0 开始,MySQL 新增了一个叫窗口函数的概念,它可以用来实现若干新的查询方式。

    窗口函数有点像是 SUM()COUNT() 那样的集合函数,但它并不会将多行查询结果合并为一行,而是将结果放回多行当中。也就是说,窗口函数是不需要 GROUP BY 的。

  7. 新的系统字典表

    整合了存储有关数据库对象信息的事务数据字典,所有的元数据都用 InnoDB 引擎进行存储

  8. 安全和用户管理

    新增 caching_sha2_password 认证插件,并且是默认的身份认证插件。性能和安全方面加强

    权限支持 role

    新增密码历史记录功能,限制重复使用以前的密码

  9. innodb 增强

    新增 INFORMATION_SCHEMA.INNODB_CACHED_INDEXES,查看每个索引缓存在 InnoDB 缓冲池中的索引页数

    新增 INFORMATION_SCHEMA.INNODB_TABLESPACES_BRIEF 视图

    新增了动态配置项 innodb_deadlock_detect,用来禁用死锁检查,因为在高并发系统中,当大量线程等待同一个锁时,死锁检查会大大拖慢数据库

    支持使用 innodb_directories 选项在服务器脱机时将表空间文件移动或恢复到新位置

    新增 innodb_dedicated_server,让 InnoDB 根据服务器上检测到的内存量自动配置 innodb_buffer_pool_size, innodb_log_file_size,innodb_flush_method

    innodb_dedicated_server: 自动配置缓冲池大小

  10. 直方图

    MySQL 8.0 版本开始支持期待已久直方图。优化器会利用 column_statistics 的数据,判断字段的值的分布,得到更准确的执行计划。

    可以使用 ANALYZE TABLE table_name [UPDATE HISTOGRAM on col_name with N BUCKETS |DROP HISTOGRAM ON clo_name] 来收集或者删除直方图信息

    支持会话级别 SET_VAR 动态调整部分参数,有利于提升语句性能。

  11. InnoDB 性能提升

    废除 buffer pool mutex, 将原来一个 mutex 拆分成多个,提高并发拆分 LOCK_thd_listLOCK_thd_remove 这两个 mutex,大约可提高线程链接效率 5%。

    1. 行缓存

      MySQL 8.0 的优化器可以估算将要读取的行数,因此可以提供给存储引擎一个合适大小的 row buffer 来存储需要的数据。大批量的连续数据扫描的性能将受益于更大的 record buffer

    2. 改进扫描性能

      改进 InnoDB 范围查询的性能,可提升全表查询和范围查询 5-20%的性能。

    3. 成本模型

      InnoDB 缓冲区可以估算缓存区中的有多少表和索引,这可以让优化器选择访问方式时知道数据是否可以存储在内存中还是必须存储到磁盘上。

MySql 5.7 和 8 的选择

MySQL 8 会使用更多内存。

对运行相同轻量级工作负载的 MySQL 8 和 MySQL 5.7 (实际上它们是 Percona Server 版本) 的 1GB VM 进行基本测试。

MySQL 8 使用了大约 200MB 的 swap 分区,并且使用更少的系统缓存,被分配更多内存。

如果我们查看 top 命令的输出,我们会看到 MySQL 8 使用的更多常驻内存和虚拟内存。特别是“可怕的”虚拟内存,因为它远远超过这些 VM 上可用的 1GB 物理内存。当然,虚拟内存使用 (VSZ) 是现代应用程序实际内存需求的一个很差的指标,但它确实证实了更高的内存需求这个事。

实际上,正如我们从 vmstat 输出中所知道的那样,即使没有太多的“空间”,MySQL 8 和 MySQL 5.7 都不会在低负载下使用 swap 分区。

如果您有多个连接或希望在同一个 VM 上运行某些应用程序,则可以使用 swap (如果未启用交换,则可能导致 OOM)。这是一个有趣的实验,能看看我有多少可以驱动 MySQL 5.7 和 MySQL 8 的内存消耗。

总结在开发环境中迁移到 MySQL 8 时,请记住,使用相同的设置需要比 MySQL 5.7 配置更多的内存。