前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >故障分析 | Federated 存储引擎表导致监控线程处于 Opening table 状态

故障分析 | Federated 存储引擎表导致监控线程处于 Opening table 状态

作者头像
爱可生开源社区
发布2022-05-23 08:57:08
3230
发布2022-05-23 08:57:08
举报
文章被收录于专栏:爱可生开源社区

作者:李鹏博

爱可生 DBA 团队成员,主要负责 MySQL 故障处理和 SQL 审核优化。对技术执着,为客户负责。

本文来源:原创投稿

*爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。

最近发现客户的一台 MySQL 5.7.32 实例的监控线程状态一直处于 Opening table 状态,且都是在对 information_schema.tables 表做相关查询,如图:

通过 show open tables ;语句发现 opened tables 并不算太多:

相关参数也没有太大的不合理性:

虽然 ulimit 设置不是很大,但是也不会对此产生什么影响

查看 MySQL Error 日志也没有发现与此相关的异常。

因此只能使用 pstack 工具对 MySQL 打堆栈来进行分析,堆栈日志如下:

通过分析堆栈日志发现,问题出现在进行查询时会使用 Federated 存储引擎表对远程实例进行查询。

查看数据库使用 Federated 存储引擎的表,发现有两张表使用了 Federated 存储引擎:

通过在实例服务器上 Telnet Feferated 服务端的实例IP和端口发现是不通的:

所以推测问题原因为:监控线程在查询 information_schema.tables 表时,当需要获取 Federated 存储引擎表的信息时需要连接远端 Server ,而由于网络或其他原因无法连接时,就会导致本地监控线程处于 Opening table 状态。

接下来设计实验验证我们的想法:

  1. 启用 Federated 存储引擎
  1. 创建一张 Federated 存储引擎的表,连接的 server 不存在
  1. 查询 information_schema.tables 表,线程卡住
  1. 线程状态处于 Opening table 状态

这刚好验证了我们的想法是正确的。

本文关键字:#故障处理# #Federated存储引擎#

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-04-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 爱可生开源社区 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档