全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

记一次因线上mysql优化器误判引起慢查询事件

前言:

     收到疯狂的慢查询及请求超时报警,通过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)的使用小结  # 主键  # 一遍  # 又因  # 后期  # 都是  # 信息流  # 这是  # 选择了  # 几个  # 都有  # 出了  # 多个  # 就有  # 是这样  # 是基于  # 当你  # 这个问题  # 要去  # 而不  # 数据结构 


相关文章: 招贴海报怎么做,什么是海报招贴?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  公司网站制作需要多少钱,找人做公司网站需要多少钱?  建站主机选哪种环境更利于SEO优化?  黑客入侵网站服务器的常见手法有哪些?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  沈阳制作网站公司排名,沈阳装饰协会官方网站?  在线制作视频网站免费,都有哪些好的动漫网站?  建站主机是什么?如何选择适合的建站主机?  小程序网站制作需要准备什么资料,如何制作小程序?  公众号网站制作网页,微信公众号怎么制作?  如何快速搭建高效WAP手机网站吸引移动用户?  活动邀请函制作网站有哪些,活动邀请函文案?  制作证书网站有哪些,全国城建培训中心证书查询官网?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  如何在IIS7上新建站点并设置安全权限?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  如何快速查询网址的建站时间与历史轨迹?  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?  ,巨量百应是干嘛的?  建站之星下载版如何获取与安装?  网站专业制作公司有哪些,做一个公司网站要多少钱?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  建站之星如何快速生成多端适配网站?  深圳网站制作平台,深圳市做网站好的公司有哪些?  如何通过WDCP绑定主域名及创建子域名站点?  青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?  h5网站制作工具有哪些,h5页面制作工具有哪些?  如何在宝塔面板创建新站点?  建站之星安装后如何配置SEO及设计样式?  如何通过PHP快速构建高效问答网站功能?  制作网页的网站有哪些,电脑上怎么做网页?  已有域名和空间,如何快速搭建网站?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  清除minerd进程的简单方法  如何使用Golang安装API文档生成工具_快速生成接口文档  建站之星如何助力企业快速打造五合一网站?  如何登录建站主机?访问步骤全解析  如何在万网自助建站平台快速创建网站?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  制作网站的模板软件,网站怎么建设?  建站主机如何选?性能与价格怎样平衡?  如何在腾讯云服务器快速搭建个人网站?  Android使用GridView实现日历的简单功能  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  高端建站三要素:定制模板、企业官网与响应式设计优化 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。