【面试一题】MySql性能优化

可以分为四个部分:

一:硬件和操作系统层面的优化
  1. 硬件层面:影响mysql性能的主要是CPU,可用内存,磁盘读写速度,网络带宽
  2. 操作系统层面:操作系统的网络配置,应用文件句柄数。
    在硬件优化中,我们应该关注服务所承载的体量,然后提出合理的指标要求。避免出现资源浪费的情况。
二:架构设计层面的优化

是一个硬盘IO非常频繁的关系型数据库,在高并发和高性能的场景中,数据库必然会承受巨大的并发压力。在此时,优化方式可以分为几个部分。

  1. 搭建mysql主从集群,单个服务容易导致单点故障,一旦服务挂了。将会导致依赖mysql数据库的服务全部无法响应。主从集群和主主集群都可以去保证服务的高可用性。
  2. 读写分离设计,在读多写少的场景中,通过读写分离方案,避免读写冲突导致的性能问题。
  3. 引入分库分表的机制,通过分库节省单个服务器的IO压力。通过分表可以减少单表的数据量,从而去提升sql查询效率。
  4. 针对热点数据可以引入更为搞笑的分布式数据库,比如说Redis,MongoDB等。它们可以缓解硬盘IO压力,并提升数据检索性能
三:MySql程序配置的优化

对于Mysql数据库本身的优化,一般可以通过my.cnf配置文件完成。
比如5.7版本默认的最大连接数是151个,我们可以在配置文件中修改这个值。
第二个比如binlog日志,默认是不开启的,我们也可以在这个文件中修改开启。
第三个是缓存池BufferPool默认大小配置,这个一般和安全环境以及使用场景有关系。官方提供的只是一个默认的配置,具体情况还得由使用者去根据实际情况去修改。
关于配置项的修改,需要关注两个层面,一个是作用域,可以分为会话级别和全局范围。一个是是否支持热加载。
因此针对这两个点,我们需要注意的是,全局参数的设定,对于已经存在的会话是无法生效的。会话参数的设定随着会话的销毁而失效。
第三个是全局类的统一配置建议配置在默认文件中,否则重启服务会导致配置失效。

四:Sql执行的优化
  1. 慢sql的定位和排查,可以通过慢查询日志和慢查询日志工具分析。得到有问题的sql。
  2. 执行分析,针对慢sql,可以使用关键字explain查看sql的执行计划。可以重点关注type,key,rows,filterd等字段。从而去定位该sql执行慢的根本原因。再去做针对性优化。
  3. 使用Show profile工具。它是mysql提供的可以用来分析当前会话中sql语句资源消耗情况的工具,可以用于sql调优的测量。在当前会话中,默认情况下show profile是关闭状态。打开之后会保存最近15次的运行结果。可以分析慢sql的资源开销情况,比如IO开销,CPU开销,内存开销等等。

sql优化的规则:
1.sql的查询一定要基于索引来进行数据扫描。
2.避免索引列上使用函数或者运算符——索引失效
3.使用索引扫描,联合索引中的列,从左往右,命中越多越好。
4.尽量使用sql语句用到的索引完成排序。
5.有效的列信息,避免回表查询。
6.永远用小的结果集驱动大的结果集。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是一些常见的 MySQL 性能优化面试题: 1. 什么是索引?MySQL 中有哪些类型的索引? 索引是一种数据结构,用于加快数据库中数据的查找速度。MySQL 中可以使用多种类型的索引,包括 B-Tree 索引、哈希索引、全文索引等。 2. 如何优化查询语句的性能? 可以通过以下几种方式优化查询语句的性能: - 确保表结构设计合理,尽可能避免全表扫描。 - 使用索引,但不要过度使用,以免降低写入性能。 - 避免使用 SELECT *,只查询必要的列。 - 尽可能使用 JOIN 代替子查询。 - 避免在 WHERE 子句中使用函数,以免影响索引使用。 3. MySQL 中如何优化大表查询的性能? 可以通过以下几种方式优化大表查询的性能: - 使用分页查询,每次只查询部分数据。 - 使用索引,但不要过度使用,以免降低写入性能。 - 对查询结果进行缓存,避免重复查询。 - 对查询语句进行优化,避免全表扫描和排序操作。 4. 如何优化 MySQL 的写入性能? 可以通过以下几种方式优化 MySQL 的写入性能: - 确保表结构设计合理,尽可能避免全表扫描。 - 批量插入数据,而不是逐条插入。 - 对于需要频繁更新的表,可以考虑使用内存表。 - 使用延迟写入机制,将写入操作缓存到内存中,定期刷入磁盘。 5. 如何优化 MySQL 的内存使用? 可以通过以下几种方式优化 MySQL 的内存使用: - 合理设置缓冲池大小,包括查询缓存和 InnoDB 缓存池。 - 优化查询语句,避免不必要的排序和连接操作。 - 合理使用索引,以提高查询效率。 - 定期清理无用的数据,避免内存占用过高。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值