(一)减少数据库访问
对于可以静态化的页面,尽可能静态化
对一个动态页面中可以静态的局部,采用静态化
部分数据可以生成XML,或者文本文件形式保存
使用数据缓存技术,例如:MemCached
(二)优化的检测方法
1.用户体验检测
2.Mysql状态检测
在Mysql命令行里面使用show status命令,得到当前mysql状态。
主要关注下列属性:
key_read_requests (索引读的请求数)(key_buffer_size设置影响)
key_reads(索引读响应数)
Key_blocks_used
Qcache_*
Open_tables(通过table_cache的设置影响)
Opened_table
table_locks
3. 第三方工具检测
mysqlreporthttp://hackmysql.com/mysqlreport
mytophttp://jeremy.zawodny.com/mysql/mytop/
系统及Mysql的Log
系统命令: top, sar
Mysql的Log: slow_query.log
(三)硬件方面的优化
硬件方面,最容易成为Mysql瓶颈的部分是磁盘,其次是CPU和内存
磁盘方面:
使用更快的磁盘,会对Mysql有很好的帮助
使用更多的硬盘,通过Raid,可以提高单块磁盘速度的问题
对于Raid方式,建议采用Raid 0+1 或者 Raid 1+0
CPU:
毫无疑问,更高主频的CPU和更多的CPU数量可以给Mysql更高的性能
内存:
更高的内存,往往可以让Mysql中的更多的数据缓存在内存中,
但是,一个重要的因素是,需要有正确的Mysql的配置
网卡:
使用千兆网卡及千兆网络
(四)操作系统方面的优化
1.不使用交换区。如果内存不足,增加更多的内存或配置你的系统使用较少内存
2.不要使用NFS磁盘
3.增加系统和MySQL服务器的打开文件数量
使用ulimit –n 65535
4.增加系统的进程和线程数量。
5.关闭不必要的应用,优化硬盘参数,使用hdparm测试
(五)应用级的优化
1.使用多服务器负载均衡(多台读和写,用复制技术进行数据同步)
2.表的分区 (自定义分区,mysql5.1开始支持自带分区功能)
3.使用数据缓存技术memcached
(六)Mysql配置的优化
1.key_buffer(=512):索引缓冲使用的内存数量
这对MyISAM表来说非常重要,设定在可用内存的25%-30%较好,通过检查状态值 Key_read_requests和 Key_reads,
可以知道key_buffer设置是否合理。比例key_reads / key_read_requests应该尽可能的低,至少是1:100,1:1000更好 ,否则说明 key_buffer 设置有点偏小。
2.innodb_buffer_pool_size(= 512): 索引缓冲使用的内存数量
3.table_cache (=1024):数据表缓存区的尺寸
每当MySQL访问一个表时,如果在表缓冲区中还有空间,该表就被打开并放入其中,这样可以更快地访问表内容。
通过检查运行峰值时间的 Open_tables 和 Opened_tables 状态值,可以决定是否需要调整 table_cache 的值。
如果你发现 open_tables 的值等于 table_cache,并且发现 opened_tables 状态值在不断增长,那么你就需要增加 table_cache 参数值了,也不能盲目地把 table_cache 参数设置成很大的值,如果设置得太高,可能会造成文件描述符不足,从而造成性能不稳定或者连接失败。
4.sort_buffer_size (=256):指定排序用缓冲区的长度
该参数对应的分配内存是每连接独占!如果有100个连接,那么实际分配的总共排序缓冲区大小为100 × 6 = 600MB。
所以,对于内存在4GB左右的服务器推荐设置为6-8M
5.join_buffer_size :关联查询用缓冲区的长度
4G内存以上,建议大于32M,该参数对应的分配内存也是每连接独享!
6.max_connections (=1024):可以复用的线程数量
允许同时连接MySQL服务器的客户数量 ,可以观察和估计系统在峰值最大的并发连接数来设置
7.thread_cache(=*):可以复用的线程数量
一般设置为CPU数×2
8.innodb_buffer_pool_size(= 512):innodb表缓存池大小
这对Innodb表来说非常重要。Innodb相比MyISAM表对缓冲更为敏感。MyISAM可以在默认的 key_buffer_size 设置下运行的可以,然而Innodb在默认的innodb_buffer_pool_size 设置下却跟蜗牛似的。
由于Innodb把数据和索引都缓存起来,无需留给操作系统太多的内存,因此如果只需要用Innodb的话则可以设置它高达 70-80% 的可用内存。
一些应用于 key_buffer 的规则有 -- 如果你的数据量不大,并且不会暴增,那么无需把innodb_buffer_pool_size 设置的太大了.
9.innodb_flush_logs_at_trx_commit(=1) :事务提交后的日志刷新模式
是否为Innodb比MyISAM慢1000倍而头大?看来也许你忘了修改这个参数了。默认值是 1,这意味着每次提交的更新事务(或者每个事务之外的语句)都会刷新到磁盘中,而这相当耗费资源,尤其是没有电池备用缓存时。很多应用程序,尤其是从 MyISAM转变过来的那些,把它的值设置为 2 就可以了,也就是不把日志刷新到磁盘上,而只刷新到操作系统的缓存上。日志仍然会每秒刷新到磁盘中去,因此通常不会丢失每秒1-2次更新的消耗。如果设置 为0就快很多了,不过也相对不安全了,MySQL服务器崩溃时就会丢失一些事务。设置为2指挥丢失刷新到操作系统缓存的那部分事务。
转载:http://www.4u4v.net/mysql-database-performance-optimization.html
相关推荐
课程内容进行了精华的浓缩,有四大内容主旨,MySQL架构与执行流程,MySQL索引原理详解,MySQL事务原理与事务并发,MySQL性能优化总结与MySQL配置优化。课程安排的学习的教程与对应的学习课件,详细的学习笔以及课程...
如何进行优化,提高 MySQL 数据库的性能?如何架构部署 MySQL 集群、架构跨 IDC 的分布式 MySQL 集群?如何实现 MySQL 数据库的 HA?将在本课程中跟大家分享。 课程大纲: 第 1 课 机器选型、系统规划 机器选型 业务...
mysql服务性能优化my_cnf配置说明详解16G内存[参考].pdf
通过学习可以全面掌握数据库性能优化的各种技术手段,并能使用主从复制、读写分离等方式实现数据库的高可用性和负载均衡。 使用建议: 重点学习性能优化部分的各种技术方案,逐一对应示例代码进行理解和拓展实践。高...
完整版 MySQL8.0从入门到精通 MySQL数据库教程 第16章 性能优化(共23页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程 第17章 MySQL Replication(共27页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程...
5. MySQL数据库的安全性和性能优化 本资料内容全面,结构清晰,从MySQL的安装到配置,再到基本操作,手把手教你搭建自己的数据库环境。此外,我们还提供了丰富的实例和操作截图,让你在实际操作中轻松掌握所学知识。...
MySQL性能优化之参数配置、性能优化、内存。通过根据服务器目前状况,修改Mysql的系统参数,达到合理利用服务器现有资源,最大合理的提高MySQL性能。
mysql安装配置教程 ...通过掌握性能优化、安全性、监控与日志管理、扩展与高可用、备份与恢复以及版本升级与迁移等方面的知识,你可以更好地管理MySQL数据库,确保其稳定、高效地运行,并满足业务的需求。
《oracle数据库性能优化的艺术》重在“授人以渔”,虽然主要内容是围绕oracle数据库系统展开的,但是书中的观点同样适用于db2、sql server、mysql、postgresql等数据库系统。 oracle数据库性能优化的艺术 目录 ...
完整版 MySQL8.0从入门到精通 MySQL数据库教程 第16章 性能优化(共23页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程 第17章 MySQL Replication(共27页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程...
完整版 MySQL8.0从入门到精通 MySQL数据库教程 第16章 性能优化(共23页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程 第17章 MySQL Replication(共27页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程...
MySQL高级性能优化的关键点: 数据库设计和规范化:确保数据库表结构合理、字段类型正确,并进行适当的规范化,以减少数据冗余和提高查询效率。 索引优化:根据查询需求创建适当的索引,避免过多或不必要的索引,...
第14章 数据备份与还原(共21页).pptMySQL从入门到精通 第15章 MySQL日志(共22页).pptMySQL从入门到精通 第16章 性能优化(共18页).pptMySQL从入门到精通 第17章 MySQL Workbench5.2 的使用(共15页).pptMySQL...
描述如何优化mysql,让数据库执行语句更快,性能更佳
第十五部 MySQL数据库优化思想与优化实战(9节) 1-网站打开慢mysql问题多解决方案企业案例.avi 2-MySQL索引优化要点精讲01 3-MySQL索引优化生产案例讲解02 4-linux运维人员必须掌握的核心经验案例.avi MySQL数据库...
2. 性能优化:包括 SQL 查询优化、索引优化、数据表分区、缓存机制等。 3. 备份与恢复:包括数据备份和恢复的方法、备份数据的类型、备份与恢复的策略、日志文件管理等。 4. 数据库设计:包括数据库设计范式、数据库...
在本篇文章中,我们介绍了一些MySQL进阶技巧,包括索引优化、查询优化和数据库配置调整。
MySQL语句优化是提高数据库性能的关键步骤,它包括调整参数配置、优化SQL语句和分析执行计划等。以下是一些常见的优化策略: 使用EXPLAIN分析查询:通过在查询语句前加上EXPLAIN关键字,可以了解MySQL是如何处理该...
高级教程MySQL性能优化实战。MySQL体系架构,MySQL设计优化,MySQL系统优化,MySQL配置优化,MySQL语句优化