最近遇到一个奇怪的问题,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 应该会解决这个问题。
Just try, don't shy.