欢迎来到天天文库
浏览记录
ID:36316083
大小:948.50 KB
页数:34页
时间:2019-05-09
《mysql介绍和优化分享》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、MySQL介绍和优化分享2010-05MySQL基本介绍MySQL优化方式MySQL技巧分享Q&A目录索引MySQL基本介绍什么是MySQLMySQL是一个小型关系型数据库管理系统,开发者为瑞典MySQLAB公司。目前MySQL被广泛地应用在Internet上的中小型网站中。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库。MySQL官方网站:http://www.mysql.com谁在用MySQLMySQL历史1979年,报表工具,数据引擎1996年,MySQL1.0(3.11.1)发
2、布,支持SQL2000年,成立MySQLAB公司2008年1月,Sun公司以10亿美元收购MySQLAB公司2009年4月,Oracle公司以74亿美元收购Sun公司MySQL里程碑3.11.1Firstpublicrelease3.23集成BerkeleyDB,支持事务,抽象出StorageEngine4.0集成InnoDB4.1重大改进,子查询、unicode、c/s通信协议5.0storedprocedure、view、triggers、queryoptimizer5.1FileNDB、recordreplication......MySQL架构MySQL存储引擎
3、比较MyISAM特点MyISAMvsInnoDB数据存储方式简单,使用B+Tree进行索引使用三个文件定义一个表:.MYI.MYD.frm少碎片、支持大文件、能够进行索引压缩二进制层次的文件可以移植(LinuxWindows)访问速度飞快,是所有MySQL文件引擎中速度最快的不支持一些数据库特性,比如事务、外键约束等Tablelevellock,性能稍差,更适合读取多的操作表数据容量有限,一般建议单表数据量介于50w–200w增删查改以后要使用myisamchk检查优化表InnoDB特点MyISAMvsInnoDB使用TableSpace的方式来进行数据存储(ibda
4、ta1,ib_logfile0)支持事务、外键约束等数据库特性Rowslevellock,读写性能都非常优秀能够承载大数据量的存储和访问拥有自己独立的缓冲池,能够缓存数据和索引在关闭自动提交的情况下,与MyISAM引擎速度差异不大MyISAMvsInnoDB性能测试数据量/单位:万MyISAMInnoDB备注:my.cnf特殊选项插入:1w3秒219秒innodb_flush_log_at_trx_commit=1插入:10w29秒2092秒innodb_flush_log_at_trx_commit=1插入:100w287秒N/Ainnodb_flush_log_at
5、_trx_commit=1插入:1w3秒3秒innodb_flush_log_at_trx_commit=0插入:10w30秒29秒innodb_flush_log_at_trx_commit=0插入:100w273秒423秒innodb_flush_log_at_trx_commit=0插入:1wN/A3秒innodb_flush_log_at_trx_commit=0innodb_buffer_pool_size=256M插入:10WN/A26秒innodb_flush_log_at_trx_commit=0innodb_buffer_pool_size=256M插
6、入:100WN/A379秒innodb_flush_log_at_trx_commit=0innodb_buffer_pool_size=256M测试结果MyISAMvsInnoDB性能测试可以看出在MySQL5.0里面,MyISAM和InnoDB存储引擎性能差别并不是很大,针对InnoDB来说,影响性能的主要是innodb_flush_log_at_trx_commit这个选项,如果设置为1的话,那么每次插入数据的时候都会自动提交,导致性能急剧下降,应该是跟刷新日志有关系,设置为0效率能够看到明显提升,当然,同样你可以SQL中提交“SETAUTOCOMMIT=0”来设
7、置达到好的性能。同时也可以看出值得使用InnoDB来替代MyISAM引擎来进行开发,毕竟InnoDB有多数据库特性、更良好的数据存储性能和查询性能MySQL优化方式系统优化:硬件、架构服务优化应用优化MySQL优化方式使用好的硬件,更快的硬盘、大内存、多核CPU,专业的存储服务器(NAS、SAN)设计合理架构,如果MySQL访问频繁,考虑Master/Slave读写分离;数据库分表、数据库切片(分布式),也考虑使用相应缓存服务帮助MySQL缓解访问压力系统优化配置合理的MySQL服务器,尽量在应用本身达到一个MySQL最合理的使用针对My
此文档下载收益归作者所有