分享下mysql各个主要版本之间的差异
showinnodbstatus\Gmysql-5.1
showenginesinnodbstatus\Gmysql-5.5
关于grant授权mysql-5.5的user@"%"不包含localhost
二、MySQL4.1/5.0/5.1/5.5/5.6各版本的主要区别
mysql-server-4.1
增加了子查询的支持,字符集增加UTF-8,GROUPBY语句增加了ROLLUP,mysql.user表采用了更好的加密算法,innodb开始支持单独的表空间。
mysql-server-5.0
增加了Storedprocedures、Views、Cursors、Triggers、XAtransactions的支持,增加了INFORATION_SCHEMA系统数据库。
mysql-server-5.1
增加了Eventscheduler,Partitioning,PluggablestorageengineAPI,Row-basedreplication、Global级别动态修改generalquerylog和slowquerylog的支持。
小版本的重要特性:
5.1.2开始支持微秒级的慢查询。关于慢查询相关信息请参考http://linuxguest.blog.51cto.com/195664/721042
mysql-server-5.5
1)默认存储引擎更改为InnoDB
2)提高性能和可扩展性
a.提高了默认线程并发数(innodb_thread_concurrency)
b.后台输入/输出线程控制(innodb_read_io_threads、innodb_write_io_threads)
c.主线程输入/输出速率控制(innodb_io_capacity)
d.操作系统内存分配程序使用控制(innodb_use_sys_malloc)
e.适应性散列索引(HashIndex)控制,用户可以关闭适应性散列功能。
f.插入缓冲(InsertBuffering)控制,用户可以关闭innodb的插入缓冲功能。
g.通过快速加锁算法提高可扩展性,innodb不在使用代理(posix)线程,而是使用原生的独立操作来完成互斥和读写锁定。
h.恢复组提交(RestoredGroupCommit)
i.提高恢复性能
j.多缓冲池实例
k.多个回滚段(MultipleRollbackSegments),之前的innodb版本最大能处理1023个并发处理操作,现在mysql5.5可以处理高达128K的并发事物,
l.Linux系统固有的异步输入/输出,mysql5.5数据库系统也提高了linux系统的输入输出请求的并发数。
m.扩展变化缓冲:添加了删除缓冲和清除缓冲
n.改善了日志系统互斥和单独刷新(Flush)列表互斥
o.改善清除程序进度,在mysql5.5中清楚操作线程是独立的线程,并支持并发,可以使用innodb_purge_treads配置。
p.改善事务处理中的元数据锁定。例如,事物中一个语句需要锁一个表,会在事物结束时释放这个表,而不是像以前在语句结束时释放表。
3)提高实用性
a.半同步复制(Semi-synchronousReplication)
b.复制Heartbeat
c.中继日志自动恢复(AutomaticRelayLogRecovery)
d.根据服务器过滤项复制(ReplicationPerServerFiltering)
e.从服务器复制支持的数据类型转换(ReplicationSlaveSideDataTypeConversions)
4)提高易管理性和效率
a.建立快速索引(FasterIndexCreation)
b.高效的数据压缩(EfficientDataCompression)
c.为大物件和可变长度列提供高效存储
d.增加了INFORMATION_SCHEMA表,新的表提供了与InnoDB压缩和事务处理锁定有关的具体信息。
5)提高可用性
a.针对SIGNAL/RESIGNAL的新SQL语法
b.新的表/索引分区选项。MySQL5.5将表和索引RANG和LIST分区范围扩展到了非整数列和日期,并增加了在多个列上分区的能力。
6)改善检测和诊断
Mysql5.5引入了一种新的性能架构(performancn_shema,P_S),用于监控mysql监控服务器运行时的性能。
小版本的重要特性:
percona-server-5.5.18.23支持groupcommit参考:http://www.orczhou.com/index.php/2011/12/time-to-group-commit-2/
mysql-server-5.6
1)InnoDB现在可以限制大量表打开的时候内存占用过多的问题(比如这里提到的)(第三方已有补丁)
2)InnoDB性能加强。如分拆kernelmutex;flush操作从主线程分离;多个perge线程;大内存优化等
3)InnoDB死锁信息可以记录到error日志,方便分析
4)MySQL5.6支持延时复制,可以让slave跟master之间控制一个时间间隔,方便特殊情况下的数据恢复。
5)表分区功能增强
6)MySQL行级复制功能加强,可以降低磁盘、内存、网络等资源开销(只记录能确定行记录的字段即可)
7)Binlog实现crash-safe
8)复制事件采用crc32校验,增强master/slave复制数据一致性
9)新增log_bin_basename(以前variables里面没有binlog位置信息,对数据库的监管很不方便)
相关文章
- 解决Java程序连接MySQL数据库的方法(java链接mysql数据库)
- 控制掌握MySQL版本控制的能力(mysql版本)
- 解决安装不上MySQL的问题(安装不上mysql)
- 数据MySQL索引——比数据更宝贵(mysql索引大于)
- MySQL无法使用:排查最佳方案(mysql无法使用情况)
- MySQL处理二进制数据的秘籍(mysql二进制数据)
- MySQL管理之二进制数据深度剖析(mysql二进制数据)
- MySQL字段取值技巧分享(mysql字段取值)
- 使用MySQL查询中文编码问题及解决方法(mysql编码查询)
- MySQL查看数据库版本的一种方法(mysql查看数据库版本)
- MySQL中怎样使用div函数进行除法运算(mysql中 div函数)
- MySQL语法计算两句SQL语句结果的差值(mysql 两语句求差)
- 技术分享MySQL如何查询两表相等的数据(mysql两表相等的数据)
- MySQL关联查询排序技巧分享(mysql两表关联排序)
- armhf架构下编译MySQL一次成功经验分享(armhf编译mysql)
- 语句如何使用CMD实现MySQL语句执行(cmd怎么执行mysql)
- MySQL 32位版本助力企业数据分析实现前所未有进展(32位mysql版本)
- MySQL实现时间判断的简单方法(mysql中判断时间)
- MySQL一对一关系的实际应用案例分享(mysql一对一案例)
- 快速获取MySQL下载源方法分享(mysql下载源)
- Mysql 数据库丢失别慌来了解一下 MySQL 不见的可能原因及解决办法(mysql不见)