设为首页 收藏本站
查看: 871|回复: 0

[经验分享] Mysql 参数调优

[复制链接]

尚未签到

发表于 2018-10-2 13:59:12 | 显示全部楼层 |阅读模式
数据库优化(影响力从上到下减小)(1)SQL语句优化(2)数据库设计优化(3)参数优化(4)硬件资源和文件系统  从上面的列表可以看出参数对于mysql 优化来说实际上起到的作用并不是很大,如果想更好的发挥mysql性能,还是从前面2点入手较好,但并不代表对于参数的优化一点作用都没有,不代表参数优化没必要做。要优化数据库,第一步需要优化的就是IO,即尽可能将磁盘IO 转化成内存IO,众所周知,内存IO和磁盘IO 速度上并不是同一个等级的。
  下面就介绍一下一些比较常见的参数的优化:
  query_cache_size/query_cache_type (global)
  
  这两个参数是针对Query cache 的优化,Query cache用于缓存SQL语句执行的结果集(仅针对select)语句。若Mysql已打开Query cache,那么当Mysql 接受到select语句请求后,如果命中缓存,则直接通过Query cache 返回结果,从而忽略后面所有步骤(如SQL语句的解析,优化器优化,向存储引擎请求数据等),进而极大的提高性能。
  对于Query cache来说最重要的参数便是query_cache_size 和 query_cache_type,前者用于设置缓存resultset的内存大小,后者设置什么场景下使用Query cache。
  一般来说query_cache_size 设置为256M是一个比较合适的大小,不过具体还得根据Query cache 的命中率(Qcache_hits/(Qcache_hits+Qcache_inserts)*100))来进行相应调整。
  query_cache_type [0|1|2]
  0(OFF) 表示完全不使用query_cache
  1(ON) 表示除显示要求不使用query_cache(使用了sql_no_cache)之外的所有select语句都是用query cache
  2(DEMOND) 表示显示要求才使用query cache(使用了sql_cache)
  key_buffer_size (global)  
  key_buffer_size 参数用来设置用于缓存 MyISAM存储引擎中索引文件的内存区域大小。如果有足够的内存,这个缓存区域最好是能够存放下所有的 MyISAM 引擎表的所有索引,以尽可能提高性能。
  此外,当我们在使用MyISAM 存储的时候有一个及其重要的点需要注意,由于 MyISAM 引擎的特性限制了他仅仅只会缓存索引块到内存中,而不会缓存表数据库块。所以,我们的 SQL 一定要尽可能让过滤条件都在索引中,以便让缓存帮助我们提高查询效率。
  innodb_buffer_pool_size(global)
  
  对应于MyISAM 的 key_buffer_size,InnoDB存储引擎也有自己的缓存。这个常数用于设置用于缓存 InnoDB 索引及数据块的内存区域大小。简单来说,当我们操作一个 InnoDB 表的时候,返回的所有数据或者去数据过程中用到的任何一个索引块,都会在这个内存区域中走一遭。
和key_buffer_size 对于 MyISAM 引擎一样,innodb_buffer_pool_size 设置了 InnoDB 存储引擎需求最大的一块内存区域的大小,直接关系到 InnoDB存储引擎的性能,所以如果我们有足够的内存,尽可将该参数设置到足够大,将尽可能多的 InnoDB 的索引及数据都放入到该缓存区域中,直至全部。    我们可以通过 (Innodb_buffer_pool_read_requests – Innodb_buffer_pool_reads) / Innodb_buffer_pool_read_requests * 100% 计算缓存命中率,并根据命中率来调整 innodb_buffer_pool_size 参数大小进行优化。skip-locking   避免Mysql 的外部锁定,减少出错几率,增强稳定性。
skip-name-resolve  默认情况下,Mysql会自动的进行DNS解析,使用该参数可以禁止Mysql对外部连接进行DNS解析,使用这一选项可以消除Mysql 进行DNS解析时间。但需要需要的是,如果开启该选项,则所有远程主机连接授权都要使用IP地址的方式了,否则Mysql将无法正常处理连接请求。
max_allowed_packet = 4M  设定在网络传输中一次消息传输量的最大值,系统默认为1MB,最大为1GB,必须设定为1024的倍数,单位为字节。
max_connections = 5000     指定mysql 允许的最大连接进程数。如果在访问论坛时经常出现Too many connections的错误,则需要增大该值。具体数值需根据服务器性能来决定。max_connect_errors = 6000    设置每个主机的连接请求异常中断的最大次数,当超过该次数,Mysql服务器将禁止host的连接请求,知道Mysql服务器重启或者通过flush hosts 命令清空此host的相关信息。wait_timeout = 120  指定一个请求的最大连接时间,对于4GB左右内存的服务器来说,可以设置为5-10。(具体数值需根据服务器自身性能来设置)
tmp_table_size = 64M    设置内存临时表最大值,如果超过该值,则会将临时表写入磁盘,设置范围为1KB-4GB  例如order by 、group by等操作可能会用到临时表,此时如果需要的空间小于该参数tmp_table_size的值,那么mysql会将临时表建在内存中,否则自动转换到磁盘上(仅针对MyISAM 的情况)。
  binlog_cache_size
  设置binlog缓存大小,一般2MB~4MB是一个比较合适的选择,事务较大且写入频繁的数据库环境可以适当调大,但不建议超过32MB。
  暂时想到的就这些参数,以后接触到其他的再慢慢补充上来。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-607628-1-1.html 上篇帖子: AWS 新建RDS实例 for MySQL 下篇帖子: mysql-mmm
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表