记一次因线上mysql优化器误判引起慢查询事件
发布时间 - 2026-01-10 23:17:13 点击率:次前言:

收到疯狂的慢查询及请求超时报警,通过metrics分析出来自mysql请求的异常,cli —> show proceslist 看到很多慢查询。 先前该sql是没有的,后面因为数据量的增长才出现了这问题。 虽然feeds表大到一个亿,但因为feeds流信息有近期热的特征,所以不是因为 innodb_buffer_pool_size 低效引起的io频繁。 后来经过进一步explain执行计划分析得出了原因,mysql查询优化器选择了他认为高效的索引。
mysql查询优化器大多数情况是靠谱的! 但是你的sql语言含有多个索引时就要注意了,往往最后的结果令人有些彷徨了。因为mysql同一个sql只能使用一个索引,那么选择哪个呢? 在数据量小时候,mysql优化器会把主键索引后置,优先使用 index和unique 。 当你达到一个数据量级后,又因为你的查询操作有 in ,那么mysql查询优化器很可能会选用主键的 !
记住一句话,mysql查询优化是基于检索成本考虑,而不是基于时间成本考虑。 优化器是根据现有的数据状态来推算代价,而不是真的去执行一遍sql.
所以,mysql优化器并不是每次都可以达到优化的效果的。 它并不能准确预估代价,如果要准确得到走各个索引的代价就要去真的执行一遍才能知道,所以代价分析只是做了一个预估,既然是预估那么就有误判。
我们这里说的表是feed信息流表,我们知道feeds信息流表访问不仅频繁,而且数据量也很大。 但是这个表的数据结构很简单,索引也简单. 一共就两个索引,一个是主键索引, 一个是unique唯一键索引。
如下,该表的量级已经到亿级别了,因为有足够多的cache前顶,又因为这样那样的原因,所以没来的及做分库分表。
问题是这样的, 当数据量级不到一个亿的时候,mysql优化器选择使用 index索引, 当数据量级超过一个亿后,mysql查询优化器选择使用 主键索引了。 这样带来的问题就是 查询速度太慢。
这是正常情况下:
mysql> explain SELECT * FROM `feed` WHERE user_id IN (116537309,116709093,116709377) AND cid IN (1001,1005,1054,1092,1093,1095) AND id <= 128384713 ORDER BY id DESC LIMIT 0, 11 \G;
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: feed
partitions: NULL
type: range
possible_keys: PRIMARY,feed_user_target
key: feed_user_target
key_len: 6
ref: NULL
rows: 18
filtered: 50.00
Extra: Using where; Using index; Using filesort
1 row in set, 1 warning (0.00 sec)
同样的sql语句,在数据量有较大变化后,mysql查询优化器对索引的选择也有了变化。
mysql> explain SELECT * FROM `feed` WHERE user_id IN (116537309,116709093,116709377) AND cid IN (1001,1005,1054,1092,1093,1095) AND id <= 128384713 ORDER BY id DESC LIMIT 0, 11 \G;
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: feed
type: range
possible_keys: PRIMARY,feed_user_target
key: PRIMARY
key_len: 4
ref: NULL
rows: 11873197
Extra: Using where
1 row in set (0.00 sec)
那么解决方法是使用 force index,强制查询优化器使用我们给出的index 。 我这里是python开发环境,常见的python orm都有force index,ignore index,user index 参数的。
explain SELECT * FROM `feed` force index (feed_user_target) WHERE user_id IN (116537309,116709093,116709377) ...
那么我们应该怎么预防这种 因为数据的增进,mysql优化器选择了一个低效索引的问题呢?
针对这个问题请教了几个厂的dba,得到的答案和我们的方法是一样的。 都是只能通过后期的慢查询来发现问题,然后在sql语句中指定force index来解决索引问题。 另外,在系统上线初期就会做这类问题的规避,但往往业务开发人员初期都会配合dba们的审查工作,但后期为了省事,或者说自以为是认为没有问题,所以造成了 mysql查询事故。
我自己对于mysql优化器选择索引规则一知半解的,后面准备花时间好好研究下规则
# MySQL
# 慢查询
# MySQL优化器
# 优化
# MySQL慢查询优化
# MySQL优化器的SQL重写规则介绍
# mysql optimizer_switch查询优化器优化策略
# MySQL Hints控制查询优化器的选择问题小结
# 深入了解MySQL中索引优化器的工作原理
# 干涉MySQL优化器使用hash join的方法
# 探究MySQL优化器对索引和JOIN顺序的选择
# MySQL优化器追踪(Optimizer Trace)的使用小结
# 主键
# 一遍
# 又因
# 后期
# 都是
# 信息流
# 这是
# 选择了
# 几个
# 都有
# 出了
# 多个
# 就有
# 是这样
# 是基于
# 当你
# 这个问题
# 要去
# 而不
# 数据结构
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何使用Sanctum进行API认证?(SPA实战)
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
如何用西部建站助手快速创建专业网站?
Android 常见的图片加载框架详细介绍
做企业网站制作流程,企业网站制作基本流程有哪些?
Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】
html5audio标签播放结束怎么触发事件_onended回调方法【教程】
Laravel如何升级到最新版本?(升级指南和步骤)
如何在阿里云通过域名搭建网站?
如何在阿里云域名上完成建站全流程?
js代码实现下拉菜单【推荐】
如何用y主机助手快速搭建网站?
企业网站制作这些问题要关注
Android自定义listview布局实现上拉加载下拉刷新功能
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
php结合redis实现高并发下的抢购、秒杀功能的实例
Laravel如何使用withoutEvents方法临时禁用模型事件
Python高阶函数应用_函数作为参数说明【指导】
PythonWeb开发入门教程_Flask快速构建Web应用
如何快速搭建支持数据库操作的智能建站平台?
Laravel怎么在Blade中安全地输出原始HTML内容
Laravel怎么实现模型属性的自动加密
5种Android数据存储方式汇总
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
EditPlus中的正则表达式 实战(1)
百度浏览器网页无法复制文字怎么办 百度浏览器复制修复
音乐网站服务器如何优化API响应速度?
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
油猴 教程,油猴搜脚本为什么会网页无法显示?
Laravel怎么防止CSRF攻击_Laravel CSRF保护中间件原理与实践
如何快速完成中国万网建站详细流程?
Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能
JS弹性运动实现方法分析
如何用狗爹虚拟主机快速搭建网站?
Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
Laravel怎么解决跨域问题_Laravel配置CORS跨域访问
如何快速上传建站程序避免常见错误?
HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】
JS去除重复并统计数量的实现方法
晋江文学城电脑版官网 晋江文学城网页版直接进入
音响网站制作视频教程,隆霸音响官方网站?
laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法
详解MySQL数据库的安装与密码配置
高防服务器租用首荐平台,企业级优惠套餐快速部署
如何挑选最适合建站的高性能VPS主机?

