Innodb_rows_inserted 陡增

最近遇到一个奇怪的问题,Innodb_rows_inserted指标出现增长异常。

通过监控发现,在一个MySQL 集群(版本5.7)中, Innodb_rows_inserted 指标飙升,而且是只在 MySQL 从库(slave 或 secondary)上这个指标异常,主库(master 或 primary )是正常的。

排查下来发现,最近发布了新功能,会在从库上频繁查询processlist,所以导致Innodb_rows_inserted
突增。

带着疑问,首先翻看官方文档中关于Innodb_rows_inserted 的定义:

The number of rows inserted into InnoDB tables.

简单说,从定义上看,是跟插入数据有关。

但却无法解释我们遇到的情况。

于是翻看源码,希望在这里找到答案。

在源码中Innodb_rows_inserted是使用变量n_rows_inserted表示的。

在这里插入图片描述

接着,查看n_rows_inserted计算逻辑,其中一个增加计数逻辑是在函数row_insert_for_mysql_using_cursor()中,而 查询 processlist 会调用这个函数。

在这里插入图片描述

到此,可以确定Innodb_rows_inserted增长确实与查询processlist有关。

但感觉这个指标设计的并不合理,看到有文章提到MySQL 8.0 应该会解决这个问题。

  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值