zoukankan      html  css  js  c++  java
  • MySQL各版本的比较

    Mysql5.5特性,相对于Mysql5.1

    性能提升

      默认InnoDB plugin引擎。具有提交、回滚和crash恢复功能、ACID兼容。

      行级锁(一致性的非锁定读 MVCC)

      表与索引存储在表空间、表大小无限制。

      支持dynamic(primary key缓存内存 避免主键查询引起的IO )compressed(支持数据及索引压缩)行格式。

      InnoDB plugin文件格式Barracuda、支持表压缩、节约存储、提供内存命中率、truncate table速度更快。

      原InnoDB只有一个UndoSegment,最多支持1023的并发;现在有128Segments,支持128K个并发(同样,解决高并发带来的事务回滚)。

      Innodb_thread_concurrency默认为0,线程并发数无限制,可根据具体应用设置最佳值。

      Innodb_io_capacity可以动态调整刷新脏页的数量,改善大批量更新时刷新脏页跟不上导致的性能下降问题。 Default200,跟硬盘的IOPS有关。

      充分利用CPU多核处理能力innodb_read_io_threads阈值:1-64innodb_write_io_threads阈值:1-64根据数据库的读写比灵活设置,充分发挥多CPU、高性能存储设备的性能,不支持动态加载 。

      自适应刷新脏页

      热数据存活更久

      buffer pool多实例:innodb_buffer_pool_instances参数增加innodb_buffer_pool实例个数,大大降低buffer poolmutex争抢过热情况。

      Linux上实现异步IO

      重新支持组提交

    稳定性提升

      支持半同步Replication

      增加Relay Log 自我修复功能。

      Crash recovery

      引入红-黑树做插入排序的中间数据结构,时间复杂度大大降低,减少恢复时间。

      Thread Pool分组排队限流

    Mysql5.6特性,相比5.5

    默认参数的改变

      Back_log排队队列

      支持全文索引

      支持online DDL create,alter,drop

      可以在建表时指定表空间位置

              create table external (x int unsigned not null primary key)data directory = '/volumes/external1/data';

      新增参数innodb_page_size可以设置page大小

      整合了memcached API,可以使用API来直接访问innodb表,并非SQL(减少SQL解析、查询优化代价)

      innodb只读事务,不需要设置TRX_ID字段,

      减少内部数据结构开销,减少read view

      仅仅非只读事务依然需要TRX_ID

    innodb改进点

      innodb表空间在线迁移(TransportableTablespaces)

      undo log可独立出系统表空间

      redo log最大可增长到512G

      innodb后台线程独立出来

    优化器改进

      ICP:可以在引擎层直接过滤数据,避免二次回表节省BP空间,提高查询性能

      BKA:SQL通过辅助索引要访问表数据时候,将大量的随机访问放入缓存,交给MRR接口合并为顺序访问。

      MRR:BKA算法应用之后,通过MRR接口合并随机访问为顺序访问,再去检索表数据。

           变大量随机为顺序访问。在通过辅助索引检索大量数据时,性能提升明显

           磁头无需来回寻道,page只需读取一次,且较好利用了innodb线性预读功能(每次预读64个连续page)。

       统计信息持久化,mysqld重启后不丢失

      explain语句支持insertupdatedeletereplace语句,并且支持JSON格式

      子查询优化提升。

    Mysql5.7特性,相比5.5 5.6

      MySQL 5.6:初始化数据时需要进到家目录的script目录下

      MySQL 5.7:初始化数据时需要进到家目录的bin目录下

      已然已经废弃了使用mysql_install_db这个命令进行初始化数据的操作了。使用mysqld --initialize

    安全性用户表mysql.userplugin字段不允许为空,默认值是mysql_native_password,而不是mysql_old_password,不再支持旧密码格式;

      增加密码过期机制,过期后需要修改密码,否则可能会被禁用,或者进入沙箱模式;

      增加密码过期机制,过期后需要修改密码,否则可能会被禁用,或者进入沙箱模式;

      提供了更为简单SSL安全访问配置,并且默认连接就采用SSL的加密方式。

    灵活性:MySQL数据库从5.7.8版本开始,也提供了对JSON的支持。

      可以混合存储结构化数据和非结构化数据,同时拥有关系型数据库和非关系型数据库的优点

      能够提供完整的事务支持

      generated columnMySQL 5.7引入的新特性,所谓generated column,就是数据库中这一列由其他列计算而得

    易用性MySQL 5.7之前,如果用户输入了错误的SQL语句,按下ctrl+c,虽然能够结束”SQL语句的运行,但是,也会退出当前会话,MySQL 5.7对这一违反直觉的地方进行了改进,不再退出会话。

      MySQL 5.7可以explain一个正在运行的SQL,这对于DBA分析运行时间较长的语句将会非常有用。

      sys schemaMySQL 5.7.7中引入的一个系统库,包含了一系列视图、函数和存储过程, 该项目专注于MySQL的易用性。

        例如:如何查看数据库中的冗余索引;如何获取未使用的索引;如何查看使用全表扫描的SQL语句。

    可用性:MySQL 5.7通过避免为只读事务分配事务ID,不为只读事务分配回滚段,减少锁竞争等多种方式,优化了只读事务的开销,提高了数据

      在线设置复制的过滤规则 不再需要重启MySQL,只需要停止SQL thread,修改完成以后,启动SQL thread

      在线修改buffer pool的大小。

      Online DDL MySQL 5.7支持重命名索引和修改varchar的大小,这两项操作在之前的版本中,都需要重建索引或表。

      在线开启GTID,在之前的版本中,由于不支持在线开启GTID,用户如果希望将低版本的数据库升级到支持GTID的数据库版本,需要先关闭数据库,再以GTID模式启动,所以导致升级起来特别麻烦。

    性能

      临时表的性能改进。

      临时表只在当前会话中可见

      临时表的生命周期是当前连接(MySQL宕机或重启,则当前连接结束)

      只读事务性能改进库的整体性能。

      加速连接处理。

      在MySQL 5.7之前,变量的初始化操作(THDVIO)都是在连接接收线程里面完成的,现在将这些工作下发给工作线程,以减少连接接收线程的工作量,提高连接的处理速度。这个优化对那些频繁建立短连接的应用,将会非常有用。

      复制性能的改进 (支持多线程复制(Multi-Threaded Slaves, 简称MTS

      MySQL的默认配置是库级别的并行复制,为了充分发挥MySQL 5.7的并行复制的功能,我们需要将slave-parallel-type配置成LOGICAL_CLOCK

      支持多源复制(Multi-source replication

    严格性改变

      默认启用STRICT_TRANS_TABLES模式。

      对ONLY_FULL_GROUP_BY模式实现了更复杂的特性支持,并且也被默认启用。

      其他被默认启用的sql mode还有NO_ENGINE_SUBSTITUTION

    默认参数的改变

      默认binlog格式调整为ROW格式

      默认binlog错误后的操作调整为ABORT_SERVER

      在先前的选项下(binlog_error_action=IGNORE_ERROR),如果一个错误发生,导致无法写入binlogmysql-server会在错误日志中记录错误并强制关闭binlog功能。这会使mysql-server在不记录binlog的模式下继续运行,导致从库无法继续获取到主库的binlog

      默认开启mysql崩溃时的binlog安全。

      默认调低slave_net_timeout

    安装不同

      mysql_install_db已经不再推荐使用了,建议改成mysqld --initialize完成实例初始化。如果datadir指向的目标目录下已经有数据文件,则会有[ERROR] Aborting

      在初始化时如果加上--initial-insecure,则会创建空密码的root@localhost账号,否则会创建带密码的 root@localhost账号,密码直接写在log-error日志文件中;新用户登入后需要立刻修改密码,否则无法继续后续的工作。

  • 相关阅读:
    DownloadManager
    Android(蓝牙)
    Android下集成Paypal支付
    java 网络(socket)
    java 泛型的几点备忘
    设计模式(模板方法)
    STM32F4_引领入门
    如何查找STM32开发资料
    Keil(MDK-ARM)使用教程(三)_在线调试
    Keil(MDK-ARM)使用教程(二)_菜单
  • 原文地址:https://www.cnblogs.com/5945yang/p/11492300.html
Copyright © 2011-2022 走看看