面试题:谈谈对mysql性能优化的理解

Mysql性能优化大致可以分为四个方面:

  1. 硬件和操作系统层面的优化
  2. 架构设计层面的优化
  3. Mysql程序配置的优化
  4. sql执行的优化

分别对这方面展开来说。

首先,从硬件和操作系统层面的优化来说,对于硬件层面,影响mysql性能优化的主要是cpu,可用内存大小,磁盘读写速度,网络带宽;对于操作系统层面,应用文件句柄数,操作系统的网络配置都会影响。这部分优化一般是由DBA或者运维去完成,在硬件资源的优化中,我们重点应该关注服务本身承载的体量,然后合理提出指标要求,避免出现资源浪费的现象。

其次,从架构设计层面的优化来说,mysql是磁盘io非常频繁的一个关系型数据库,在高并发和高性能的场景中,mysql数据库会承受巨大的并发压力,那么我们优化的方式主要可以分为几个部分:

  1. 搭建mysql主从集群,单个mysql服务容易导致单点故障,一旦服务宕机,会导致依赖mysql的服务全部无法响应,主从集群可以保证服务的高可用性。
  2. 读写分离设计,在读多写少的场景中,通过读写分离的设计,可以避免读写冲突导致的性能问题。
  3. 引入分库分表的机制,通过分库,降低io压力,通过分表,可以降低单表数据量从而提升sql查询效率。
  4. 针对热点数据,引入redis等更高效的数据库。

第三,从mysql程序配置优化层面,可以通过mysql配置文件,my.cnf完成,修改最大连接数;开启binglog日志;缓存池bufferpool默认大小配置。配置文件设置,一般跟用户安装环境以及使用场景有关系,因此,要具体情况具体分析。关于配置项的修改,需要关注两个层面:

  1. 配置的作用域:分为会话级别和全局范围。全局参数的设定,对于已经存在的会话是无法生效的;会话参数的设定随着花花的销毁而失效;全局类的统一配置建议配置在默认配置文件中,否则重启服务会导致配置失效。
  2. 是否支持热加载:

第四,sql执行的优化来看,可以分为三个步骤:

  1. 慢sql的定位和排查:通过慢查询日志和慢查询日志工具分析,得到有问题的sql列表。
  2. 执行计划分析:针对慢sql,可以根据关键字explain,查看当前sql的执行计划,可以重点关注type,key,rows,filter等字段,从而去定位该sql执行慢的根本原因。
  3. 使用show proflie 工具。得到所有资源的开销情况
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值