《Mysql应用21条MySQL优化建议(经验总结)》要点:
本文介绍了Mysql应用21条MySQL优化建议(经验总结),希望对您有用。如果有疑问,可以联系我们。
今天一个朋友向我咨询怎么去优化 MySQL,我按着思维整理了一下,大概粗的可以分为21个方向. 还有一些细节东西(table cache, 表设计,索引设计,程序端缓存之类的)先不列了,对一个系统,初期能把下面做完也是一个不错的系统.MYSQL必读
1. 要确保有足够的内存MYSQL必读
数据库能够高效的运行,最关建的因素需要内存足更大了,能缓存住数据,更新也可以在内存先完成.但不同的业务对内存需要强度不一样,一保举内存要占到数据的15-25%的比例,特别的热的数据,内存基本要达到数据库的80%大小.MYSQL必读
2. 需要更多更快的CPUMYSQL必读
MySQL 5.6可以利用到64个核,而MySQL每个query只能运行在一个CPU上,所以要求更多的CPU,更快的CPU会更有利于并发.MYSQL必读
3. 要选择合适的操作系统MYSQL必读
在官方建议估计最保举的是Solaris, 从实际生产中看CentOS, REHL都是不错的选择,保举使用CentOS, REHL 版本为6以后的,当然Oracle Linux也是一个不错的选择.虽然从MySQL 5.5后对Windows做了优化,但也不保举在高并发环境中使用windows.MYSQL必读
4. 合理的优化系统的参数MYSQL必读
更改文件句柄 ulimit Cn 默认1024 太小
进程数限制 ulimit Cu 不同版本不一样
禁掉NUMA numctl Cinterleave=allMYSQL必读
5. 选择合适的内存分配算法MYSQL必读
默认的内存分配就是c的malloc 现在也出现许多优化的内存分配算法:MYSQL必读
jemalloc and tcmallocMYSQL必读
从MySQL 5.5后支持声明内存储办法.
MYSQL必读
或是直接指到so文件
MYSQL必读
malloc-lib=/usr/local/lib/libtcmalloc_minimal.so
MYSQL必读
6. 使用更快的存储设备ssd或是固态卡MYSQL必读
存储介质十分影响MySQL的随机读取,写入更新速度.新一代存储设备固态ssd及固态卡的出现也让MySQL 大放异彩,也是淘宝在去IOE中干出了一个漂亮仗.MYSQL必读
7. 选择良好的文件系统MYSQL必读
保举XFS, Ext4,如果还在使用ext2,ext3的同学请尽快升级别. 保举XFS,这个也是今后一段时间Linux会支持一个文件系统.MYSQL必读
文件系统强烈保举: XFSMYSQL必读
8. 优化挂载文件系统的参数MYSQL必读
挂载XFS参数:MYSQL必读
挂载ext4参数:
MYSQL必读
如果使用SSD或是固态盘需要考虑:MYSQL必读
• innodb_page_size = 4K
• Innodb_flush_neighbors = 0MYSQL必读
9. 选择适合的IO调度MYSQL必读
正常请下请使用deadline 默认是noop
MYSQL必读
10. 选择合适的Raid卡Cache策略MYSQL必读
请使用带电的Raid,启用WriteBack, 对于加速redo log ,binary log, data file都有好处.MYSQL必读
11. 禁用Query CacheMYSQL必读
Query Cache在Innodb中有点鸡肋,Innodb的数据本身可以在Innodb buffer pool中缓存,Query Cache属于结果集缓存,如果开启Query Cache更新写入都要去检查query cache反而增加了写入的开销.MYSQL必读
在MySQL 5.6中Query cache是被禁掉了.MYSQL必读
12. 使用Thread PoolMYSQL必读
现在一个数据对应5个以上App场景比较,但MySQL有个特性随着连接增多的情况下性能反而下降,所以对于连接超过200的以后场景请考虑使用thread pool. 这是一个伟大的发明.MYSQL必读
13. 合理调整内存MYSQL必读
13.1 减少连接的内存分配
连接可以用thread_cache_size缓存,观查属于比较属不如thread pool给力.数据库在连上分配的内存如下:
MYSQL必读
read_rnd_buffer_size +MYSQL必读
join_buffer_size +MYSQL必读
sort_buffer_size +MYSQL必读
binlog_cache_size +MYSQL必读
thread_stack +MYSQL必读
2 * net_buffer_length …MYSQL必读
)
MYSQL必读
要把60-80%的内存分给innodb_buffer_pool_size. 这个不要超过数据大小了,另外也不要分配超过80%不然会利用到swap.
14. 合理选择LOG刷新机制
Redo Logs:
MYSQL必读
C innodb_flush_log_at_trx_commit = 2 // 较好性能MYSQL必读
C innodb_flush_log_at_trx_commit = 0 // 最好的情能
MYSQL必读
binlog :MYSQL必读
binlog_sync = 1 需要group commit支持,如果没这个功能可以考虑binlog_sync=0来获得较佳性能.MYSQL必读
数据文件:
MYSQL必读
15. 请使用Innodb表MYSQL必读
可以利用更多资源,在线alter操作有所提高. 目前也支持非中文的full text, 同时支持Memcache API拜访.目前也是MySQL最优秀的一个引擎.MYSQL必读
如果你还在MyISAM请考虑快速转换.MYSQL必读
16. 设置较大的Redo logMYSQL必读
以前Percona 5.5和官方MySQL 5.5比拼性能时,胜出的一个Tips就是分配了超过4G的Redo log ,而官方MySQL5.5 redo log不能超过4G. 从 MySQL 5.6后可以超过4G了,通常建Redo log加起来要超过500M. 可以通过观查redo log产生量,分配Redo log大于一小时的量即可.MYSQL必读
17. 优化磁盘的IOMYSQL必读
innodb_io_capactiy 在sas 15000转的下配置800就可以了,在ssd下面配置2000以上.MYSQL必读
在MySQL 5.6:
MYSQL必读
innodb_io_capacity_max = min(2000, 2 * innodb_io_capacity)
MYSQL必读
18. 使用独立表空间MYSQL必读
目前来看新的特性都是独立表空间支持:
truncate table 表空间回收
表空间传输
较好的去优化碎片等管理性能的增加,
整体上来看使用独立表空间是没用的.MYSQL必读
19. 配置合理的并发MYSQL必读
innodb_thread_concurrency =并发这个参数在Innodb中变化也是最频繁的一个参数.不同的版本,有可能不同的小版本也有变动.一般保举:MYSQL必读
在使用thread pool 的情况下:
innodb_thread_concurrency = 0 就可以了.
如果在没有thread pool的情况下:
5.5 保举:innodb_thread_concurrency =16 C 32
5.6 保举innodb_thread_concurrency = 36MYSQL必读
20. 优化事务隔离级别MYSQL必读
默认是 Repeatable read
保举使用Read committed binlog格式使用mixed或是Row
较低的隔离级别 = 较好的性能MYSQL必读
21. 注重监控MYSQL必读
任环境离不开监控,如果少了监控,有可能就会陷入盲人摸象. 保举zabbix+mpm构建监控.MYSQL必读
维易PHP培训学院每天发布《Mysql应用21条MySQL优化建议(经验总结)》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。
转载请注明本页网址:
http://www.vephp.com/jiaocheng/9522.html