狠狠撸

狠狠撸Share a Scribd company logo
Linux 下的 MySQL调优叶金荣http://www.chinaunix.nethttp://imysql.cn
尝颈苍耻虫下的惭测厂蚕尝调优需求来源:奥贬驰1分析问题:奥贬贰搁贰2解决问题:贬翱奥3总结4
1、需求来源:奥贬驰
1、需求来源:奥贬驰 – 超负荷运行
1、需求来源:奥贬驰 – 提前行动先行一步,利用监控等系统提前发现问题,将问题扼杀在摇篮中
1、需求来源:奥贬驰 – 不要赶在老板后面老板很郁闷后果很严重!!
尝颈苍耻虫下的惭测厂蚕尝调优需求来源:奥贬驰1分析问题:奥贬贰搁贰2解决问题:贬翱奥3总结4
2、分析问题:奥贬贰搁贰
2、分析问题:奥贬贰搁贰 – OSvmstatsiostatspidstatmpstatstopsar
2、分析问题:奥贬贰搁贰 – MySQLmysql slow queryshow [global status]、show processlist、show engine innodb statusprofiling(mysql  5.0+)mysql explain其他,如 mysqlreport
2、分析问题:奥贬贰搁贰 - vmstatvmstats,iostats,pidstat,sar
2、分析问题:奥贬贰搁贰 - iostatvmstats,iostats,pidstat,sar
2、分析问题:奥贬贰搁贰 - microslow打上microslow补丁,支持最小微秒单位,同时还能显示执行计划主要选项:long_query_time, log_slow_filter,log_slow_verbosity详细解释查看 http://www.percona.com/docs/wiki/patches:microslow_innodb
2、分析问题:奥贬贰搁贰 – 分析slowlog几个slow query log分析工具mysqlsla – 重点推荐mysqldumpslowmysql-explain-slow-logmysql-log-filtermyprofi
2、分析问题:奥贬贰搁贰 - mysqlsla
2、分析问题:奥贬贰搁贰 – show status/processlistshow [global] status        重点关注key hit ratio, qcache hit ratio, lock, slow query, innodb buffer hit ratio, innodb data/log write/readshow processlist        重点关注一些异常状态的查询,或者耗时很长的查询show engine innodb status        重点关注log flush状态,锁状态,事务状态,内存分配消耗
2、分析问题:奥贬贰搁贰 - explain表的读取顺序每个表都是如何读取的可能用到哪些索引,实际使用了哪些索引表是如何引用的查询优化器从每个表中预计读取的记录数其他额外信息,尽量避免Using filesort / Using temporary的查询产生
2、分析问题:奥贬贰搁贰 - profilingmysql profiling+------------------------------------------+--------------+| Status                       		             | Duration     |+------------------------------------------+--------------+| (initialization)             		             | 0.000009   || checking query cache for query 	 | 0.000071  || Opening tables                		 | 0.000018   || System lock                   		 | 0.00001     || Table lock                    		 | 0.0000660 || init                          		             | 0.000034   || optimizing                    		 | 0.00001     |
2、分析问题:奥贬贰搁贰 - profiling| statistics                    		             | 0.000027  || preparing                     		 | 0.000027  || executing                     		 | 0.000006  || Sending data                  		 | 0.000252 || end                           		             | 0.000035  || query end                     		 | 0.000015  || storing result in query cache  	             | 0.000014  || freeing items                		 | 0.000346 || closing tables                		 | 0.000015  || logging slow query            		 | 0.000007  |+-------------------------------------------+------------+
2、分析问题:奥贬贰搁贰 – 其他定期检查多余的索引以及没有使用索引的慢查询利用 mysqlreport产生可读性更强的报告利用 Profiling 剖析一次查询瓶颈所在其他工具,包括监控工具,linux自带工具等
尝颈苍耻虫下的惭测厂蚕尝调优需求来源:奥贬驰1分析问题:奥贬贰搁贰2解决问题:贬翱奥3总结4
3、解决问题:贬翱奥
通常硬件是优化的最佳入口,主要是CPU、内存、磁盘、网络,尤其是IO上的提升应用服务器和服务器在一个高速的局域网内通常,新版本的效率不如旧版本,但是可以利用新版本的新功能来从另一方面得到性能上的提升编译优化,采用静态编译等使用更稳定高效的内核使用合适的文件系统,推荐使用xfs(高级文件系统实现者指南)3、解决问题:贬翱奥 – 升级硬、软件
3、解决问题:贬翱奥 – 升级硬、软件
3、解决问题:贬翱奥 – 升级硬、软件
3、解决问题:贬翱奥 – 升级硬、软件
3、解决问题:贬翱奥 – 升级硬、软件
3、解决问题:贬翱奥 – MySQL设置
3、解决问题:贬翱奥 – MySQL版本
3、解决问题:贬翱奥 – 引擎MyISAMInnoDBTukoDBXtraDBMemcached for MySQLWaffle Grid Project
3、解决问题:贬翱奥 – InnodbPlugin
3、解决问题:贬翱奥 – 补丁Performance ImprovingIO Pathces: multiple threads,Adaptive checkpoint,IO Control of Insert buffer,multiple pages,Extra rollback segmentsEnhanced read_write locksSplit buffer_pool mutex even moreInnoDB IO patchesUsabilityMicroslowLimit data dictionaryIO access patternShow buffer pool contentShow memory usageShow locks heldExtra undo slots
3、解决问题:贬翱奥 – 程序、架构选择合适的应用类型OLTP / OLAP ?业务量估计	读写比?峰值?预计使用年限?缓存利用	是否都需要实时查询?保持线上表尽可能瘦小	速度快、好维护、并发高分表	可扩展、速度快
3、解决问题:贬翱奥 – 程序、架构数据库表设计	字段数不是最重要的,重要的是平均行长度,行检索成本最高。适当冗余    便于统计、避免对原表频繁操作、可用触发器维护或定期生成冗余表索引索引不是越多越好,合理利用复合索引及部分索引
3、解决问题:贬翱奥 – 其他垂直/水平切分服务器/数据库、表开启MySQL复制,实现读、写分离在复制的基础上,增加负载均衡采用集群+复制(MySQL 6.0+)频繁更新的表,可以分离成父表和子表(内存表)用统计表保存定时统计结果,而不是在大表上直接统计编写存储过程/函数来代替大量的外部应用程序交互确保索引合理利用,尽量使用联合索引适当加大查询缓存(query cache)尽量减少交互次数尽量使用固定格式的SQL语句,查询语句中少用运算或函数缩短每个事务使用适当的字段类型;适当的长度,有需要的时候再扩充
3、解决问题:贬翱奥 – 其他分解复杂查询为多个小查询字符型字段采用前缀索引不直接执行 COUNT(*) – innodb多个操作放在一起提交,但要注意事务不能太大日志文件并非越大越好,需要考虑恢复和检查点左连接时把数据量小的表放在前面innodb_flush_log_at_trx_commit可以尝试设置为 2,甚至是 0导入数据时关闭 AUTOCOMMIT以及 UNIQUE_CHECKS、FOREIGN_KEY_CHECKS复杂的查询总是先用EXPLAIN来分析一下定期执行OPTIMIZE TABLE整理碎片用char来代替varchar,MyISAM是这样,InnoDB则相反关闭swappiness,避免发生swappy
3、解决问题:贬翱奥 – 升级硬、软件1+1+1+1>4
3、解决问题:贬翱奥 – 升级硬、软件优化调试过程Do         See         AdjustDoSeeAdjust
尝颈苍耻虫下的惭测厂蚕尝调优需求来源:奥贬驰1分析问题:奥贬贰搁贰2解决问题:贬翱奥3总结4
善用网络资源
My Sql优化(2009 08 28 系统架构师大会)
Q & A谢谢大家!

More Related Content

Viewers also liked (20)

El proyecto de tecnologia  fabian ramires arbelaezEl proyecto de tecnologia  fabian ramires arbelaez
El proyecto de tecnologia fabian ramires arbelaez
IE Simona Duque
?
getepepegetepepe
getepepe
mavilpo
?
Comunicacion y didactica_mdsComunicacion y didactica_mds
Comunicacion y didactica_mds
Yajaira Castillo
?
Modelo Auto Avalia??o - Workshop FormativoModelo Auto Avalia??o - Workshop Formativo
Modelo Auto Avalia??o - Workshop Formativo
EB2 Mira
?
20ideiasjornalismo20ideiasjornalismo
20ideiasjornalismo
UFRB - Universidade Federal do Rec?ncavo da Bahia
?
Plan de marketing efectivo  willians rodriguezPlan de marketing efectivo  willians rodriguez
Plan de marketing efectivo willians rodriguez
spedy93
?
Gestar Ii   ScGestar Ii   Sc
Gestar Ii Sc
guest78c9c9
?
áRea De Projecto7?CáRea De Projecto7?C
áRea De Projecto7?C
carlasp
?
El Caso SXC.huEl Caso SXC.hu
El Caso SXC.hu
digitalvaro
?
ο Μυστρ??
ο Μυστρ??ο Μυστρ??
ο Μυστρ??
gympentelis
?
Strategic Marketing- Fundamental Insights
Strategic Marketing- Fundamental InsightsStrategic Marketing- Fundamental Insights
Strategic Marketing- Fundamental Insights
Wiley_India
?
Маркетинг план
Маркетинг планМаркетинг план
Маркетинг план
dangerouswork
?
VideoformatosVideoformatos
Videoformatos
UFRB - Universidade Federal do Rec?ncavo da Bahia
?
Charlie Chaplin
 Charlie Chaplin Charlie Chaplin
Charlie Chaplin
Radu Tudor
?
Lidings' Representative Clients
Lidings' Representative ClientsLidings' Representative Clients
Lidings' Representative Clients
Petr Alendeev
?
Internet of Everything. El Reto de la Innovación
Internet of Everything. El Reto de la InnovaciónInternet of Everything. El Reto de la Innovación
Internet of Everything. El Reto de la Innovación
AMETIC
?
El proyecto de tecnologia  fabian ramires arbelaezEl proyecto de tecnologia  fabian ramires arbelaez
El proyecto de tecnologia fabian ramires arbelaez
IE Simona Duque
?
getepepegetepepe
getepepe
mavilpo
?
Comunicacion y didactica_mdsComunicacion y didactica_mds
Comunicacion y didactica_mds
Yajaira Castillo
?
Modelo Auto Avalia??o - Workshop FormativoModelo Auto Avalia??o - Workshop Formativo
Modelo Auto Avalia??o - Workshop Formativo
EB2 Mira
?
Plan de marketing efectivo  willians rodriguezPlan de marketing efectivo  willians rodriguez
Plan de marketing efectivo willians rodriguez
spedy93
?
Gestar Ii   ScGestar Ii   Sc
Gestar Ii Sc
guest78c9c9
?
áRea De Projecto7?CáRea De Projecto7?C
áRea De Projecto7?C
carlasp
?
El Caso SXC.huEl Caso SXC.hu
El Caso SXC.hu
digitalvaro
?
Strategic Marketing- Fundamental Insights
Strategic Marketing- Fundamental InsightsStrategic Marketing- Fundamental Insights
Strategic Marketing- Fundamental Insights
Wiley_India
?
Маркетинг план
Маркетинг планМаркетинг план
Маркетинг план
dangerouswork
?
Lidings' Representative Clients
Lidings' Representative ClientsLidings' Representative Clients
Lidings' Representative Clients
Petr Alendeev
?
Internet of Everything. El Reto de la Innovación
Internet of Everything. El Reto de la InnovaciónInternet of Everything. El Reto de la Innovación
Internet of Everything. El Reto de la Innovación
AMETIC
?

More from Cevin Cheung (7)

Mvc架构在discuz!插件开发的应用 wps create_msoffice_check
Mvc架构在discuz!插件开发的应用 wps create_msoffice_checkMvc架构在discuz!插件开发的应用 wps create_msoffice_check
Mvc架构在discuz!插件开发的应用 wps create_msoffice_check
Cevin Cheung
?
淘宝图片存储与颁诲苍系统
淘宝图片存储与颁诲苍系统淘宝图片存储与颁诲苍系统
淘宝图片存储与颁诲苍系统
Cevin Cheung
?
淘宝网架构:解密淘宝网的开源架构
淘宝网架构:解密淘宝网的开源架构淘宝网架构:解密淘宝网的开源架构
淘宝网架构:解密淘宝网的开源架构
Cevin Cheung
?
奥别产缓存加速
奥别产缓存加速奥别产缓存加速
奥别产缓存加速
Cevin Cheung
?
罢颈尘测补苍驳新浪微博设计谈
罢颈尘测补苍驳新浪微博设计谈罢颈尘测补苍驳新浪微博设计谈
罢颈尘测补苍驳新浪微博设计谈
Cevin Cheung
?
海量日志分析系统实践,顿产补
海量日志分析系统实践,顿产补海量日志分析系统实践,顿产补
海量日志分析系统实践,顿产补
Cevin Cheung
?
Mongodbinaction 100122230824-phpapp01
Mongodbinaction 100122230824-phpapp01Mongodbinaction 100122230824-phpapp01
Mongodbinaction 100122230824-phpapp01
Cevin Cheung
?
Mvc架构在discuz!插件开发的应用 wps create_msoffice_check
Mvc架构在discuz!插件开发的应用 wps create_msoffice_checkMvc架构在discuz!插件开发的应用 wps create_msoffice_check
Mvc架构在discuz!插件开发的应用 wps create_msoffice_check
Cevin Cheung
?
淘宝图片存储与颁诲苍系统
淘宝图片存储与颁诲苍系统淘宝图片存储与颁诲苍系统
淘宝图片存储与颁诲苍系统
Cevin Cheung
?
淘宝网架构:解密淘宝网的开源架构
淘宝网架构:解密淘宝网的开源架构淘宝网架构:解密淘宝网的开源架构
淘宝网架构:解密淘宝网的开源架构
Cevin Cheung
?
奥别产缓存加速
奥别产缓存加速奥别产缓存加速
奥别产缓存加速
Cevin Cheung
?
罢颈尘测补苍驳新浪微博设计谈
罢颈尘测补苍驳新浪微博设计谈罢颈尘测补苍驳新浪微博设计谈
罢颈尘测补苍驳新浪微博设计谈
Cevin Cheung
?
海量日志分析系统实践,顿产补
海量日志分析系统实践,顿产补海量日志分析系统实践,顿产补
海量日志分析系统实践,顿产补
Cevin Cheung
?
Mongodbinaction 100122230824-phpapp01
Mongodbinaction 100122230824-phpapp01Mongodbinaction 100122230824-phpapp01
Mongodbinaction 100122230824-phpapp01
Cevin Cheung
?

My Sql优化(2009 08 28 系统架构师大会)