深入MySQL优化:提升数据库性能的关键策略
创始人
2025-07-14 10:30:30
0

MySQL优化

从设计上,可根据需要:分库分表、读写分离、冷热分离、使用缓存、定期进行数据清理。

从客户端使用上,使用连接池、避免大事务、返回数据多使用物理分页。

从优化MySQL配置文件上,调整MySQL配置文件中的参数,如缓冲区大小、最大连接数等,以适应应用程序的需要。

从优化表结构上,使用合适的存储引擎;避免使用大型或不必要的列,并尽可能使用小型数据类型;尽量把字段设置为NOT NULL;对于某些文本字段来说,例如“省份”或者“性别”,我们可以将他们定义为ENUM(枚举)类型。因为在MySQL中,ENUM类型被当做数值型数据来处理,而数值型数据被处理起来的速度要比文本类型要快得多。

从优化查询上,善用EXPLAIN查看SQL执行计划;使用连接(JOIN)来代替子查询,减少在内存中创建临时表;尽量用union all代替union减少排序;利用小表去驱动大表,减少嵌套循环中的循环次数,以减少 IO总量及CPU运算的次数;善用索引。 

查询在什么时候不走索引、索引失效 

1.不满足走索引的条件,常见的情况有 

1.1 不满足最左匹配原则 

1.2 查询条件使用了函数 

1.3 or操作有一个字段没有索引 

1.4 使用like条件以%开头 

1.5 显式或隐式类型转换导致索引失效 

1.6 存在范围查询,比如between、>、<等条件时,会造成后面的索引字段失效 

2.走索引效率低于全表扫描,常见的情况有 

2.1 查询条件对null做判断,而null的值很多   

2.2 一个字段区分度很小,比如性别、状态 

3.需要回表的查询结果集过大,超过了配置的范围 

Explain解释 

type列,连接类型。一个好的SQL语句至少要达到range级别。杜绝出现all级别。 

key列,使用到的索引名。如果没有选择索引,值是NULL。可以采取强制索引方式。 

key_len列,索引长度

rows列,扫描行数。该值是个预估值。 

extra列,详细说明。注意,常见的不太友好的值,如下:Using filesort,Using temporary。 

如何解决大事务问题? 

解决大事务问题常规的方法有:避免远程调用、避免一次性处理太多数据、覆盖方法粒度尽量小。

具体到解决问题,需要考虑是什么、为什么、怎么办三个方面。

是什么是要界定大事务。比如可以把大事务分成了三个级别,分别是1s以上,500ms以上和100ms以上。1s以上会严重影响数据库性能,有很大概率会造成整体链路超时,是重要紧急的。之前通过事务中不包含外部调用之后,偶尔会有100ms左右的大事务,超过120ms的基本没有。这些我们记录在一个文档中,在涉及其他相关修改时,一起通过梳理逻辑优化解决。

如果把RR改成RC需要注意哪些问题?

在现代互联网场景下,其实很少需要在一个事务中对同一行数据读取两次的情况,RR隔离级别实用性不高,而且因为加了间隙锁和Next-Key Lock,性能有所降低,死锁概率也相对较高。在历史上,RR确实解决了mysql主从复制时的一个问题。在早期的mysql版本中,只有statement这种bin log格式,这时候,如果使用提交读(Read Committed)、未提交读(Read Uncommitted)这两种隔离级别会因为回放顺序而出现与主库数据不一致。MySQL是在5.1.5版本开始支持row的、在5.1.8版本中开始支持mixed,后面这两种可以代替 statement格式。RC 隔离级别只支持row格式的binlog。如果指定了mixed作为 binlog 格式,那么如果使用RC,服务器会自动使用基于row 格式的日志记录。 


相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...