show engine inndob status执行流程简析

本文涉及的产品
RDSClaw,2核4GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: show engine inndob status执行流程简析

词法分析

主要是通过DFA有限状态机进行词素分析,并且返回相关的token和token对应的值,供语法分析阶段使用。而语句里面实际上主要是这4个词素show/engine/innodb/status

token(终结符包含)SHOW/ENGINE_SYM /STATUS_SYM,在符号表中包含:

  • {SYM("SHOW", SHOW)},
  • {SYM("ENGINE", ENGINE_SYM)},
  • {SYM("STATUS", STATUS_SYM)},

而词素innodb为标识符IDENT。其次可以查看Lex_hash::get_hash_symbol函数观察语法分析中如何查阅的符号表返回token的。及如下:

#0  Lex_hash::get_hash_symbol (this=0x842a410 <Lex_hash::sql_keywords>, s=0xad36f88 "show engine innodb status", 
    len=4) at /newdata/mysql-8.0.23/sql/sql_lex_hash.cc:75
#1  0x00000000037b144b in find_keyword (lip=0x7fffbc564a58, len=4, function=false)
    at /newdata/mysql-8.0.23/sql/sql_lex.cc:875
#2  0x00000000037b2b80 in lex_one_token (yylval=0x7fffbc562ef0, thd=0xad326c0)
    at /newdata/mysql-8.0.23/sql/sql_lex.cc:1480

语法分析:

然后就是进入语法分析,这里用到是yacc/bsion,语法分析主要是采用LALR,最右推导,自底向上通过终结符(token)不断的移入/归约,进行语法的验证,最终生成AST抽象语法树,那么重点就是找到相应的规则和action,其匹配规则流程如下:

start_entry
 sql_statement
 simple_statement_or_begin
 simple_statement
 show_engine_status_stmt:
          SHOW ENGINE_SYM engine_or_all STATUS_SYM
          {
            $$ = NEW_PTN PT_show_engine_status(@$, $3);
          }
        ;

最终规则show_engine_status_stmt的action主要是构造PT_show_engine_status类,其他已经是终结符,而engine_or_all为非终结符,继续匹配规则最后为IDENT为标识符直接输入到$3,我们这里就是字符串innodb

  • PT_show_engine_status <-继承 PT_show_engine_base <-继承PT_show_base <-继承 Parse_tree_root

这个节点就是语法树的根节点,没有其他节点了,因为这属于简单的命令。其中对于每种类型的语句通常有一个对应的类型的根节点,都继承来自Parse_tree_root类然后对语法树进行实例化,也就是和具体执行函数关联,其中PT_show_engine_status包含私有成员,

Sql_cmd_show_engine_status m_sql_cmd

而其继承关系如下:

  • Sql_cmd_show_engine_status <-继承 Sql_cmd_show_noplan <-继承 Sql_cmd_show <-继承 Sql_cmd_select <-继承 Sql_cmd_dml <-继承Sql_cmd

在实例化的时候PT_show_engine_status::make_cmd并没有太多的动作,检查一下引擎是否存在,然后直接return &m_sql_cmd,返回个LEX::m_sql_cmd存放在thd->lex中,也就是把Sql_cmd_show_engine_status的对象放到thd->lex,那么Sql_cmd类实际上就是解析器和执行器之间的桥梁。

执行阶段:

执行阶段由调用从LEX中获取m_sql_cmd,调用执行函数执行,也就是Sql_cmd的纯虚函数virtual bool execute(THD *thd) = 0;由于Sql_cmd_show_noplan进行了重写,调用的是Sql_cmd_show_noplan的execute,然后由于Sql_cmd_show_noplan的execute调用Sql_cmd_show_engine_status::execute_inner,调入了ha_show_status,开始扫描引擎打印信息,当然最终会调入innobase_show_status函数进行打印innodb的各种信息,如下:

#3  0x0000000004f3ba5b in innodb_show_status (hton=0xaa45010, thd=0xad326c0, 
   stat_print=0x3b7e3d0 <stat_print(THD*, char const*, size_t, char const*, size_t, char const*, size_t)>)
   at /newdata/mysql-8.0.23/storage/innobase/handler/ha_innodb.cc:18275
#4  0x0000000004f3c818 in innobase_show_status (hton=0xaa45010, thd=0xad326c0, 
   stat_print=0x3b7e3d0 <stat_print(THD*, char const*, size_t, char const*, size_t, char const*, size_t)>, 
   stat_type=HA_ENGINE_STATUS) at /newdata/mysql-8.0.23/storage/innobase/handler/ha_innodb.cc:18660
#5  0x0000000003b7e776 in ha_show_status (thd=0xad326c0, db_type=0xaa45010, stat=HA_ENGINE_STATUS)
   at /newdata/mysql-8.0.23/sql/handler.cc:7577
#6  0x0000000003889646 in Sql_cmd_show_engine_status::execute_inner (this=0xb498fd8, thd=0xad326c0)
   at /newdata/mysql-8.0.23/sql/sql_show.cc:467
#7  0x0000000003899a5a in Sql_cmd_show_noplan::execute (this=0xb498fd8, thd=0xad326c0)
   at /newdata/mysql-8.0.23/sql/sql_show.h:186

这个过程只是简单的语句,也就是规则中定义的simple_statement 比如show/analyze/unlock/lock等等,具体可以参考yacc/bsion规则中的定义,感觉就是那种不需要执行计划的语句,这个类型的语句都可以根据这种方法进行分析。

对于select这种语句显然语法分析的结果是将生成AST树后进行实例化后进入优化器进行执行计划生成,肯定要比简单类型的语句复杂得多,后面我们再做分析。

最后

在执行show engine的时候他的状态几乎就是show processlist的starting 状态,如下:因此如果show engine语句在打印innodb信息的时候出现了很慢的情况,show processlist 看到的应该是starting,如下:

这个时候需要借助其他手段进行分析了比如pstack。


Enjoy MySQL:)


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
SQL 关系型数据库 数据库
学习分布式事务Seata看这一篇就够了,建议收藏
学习分布式事务Seata看这一篇就够了,建议收藏
24049 2
|
28天前
|
关系型数据库 MySQL 数据库
MySQL 5.7 安装教程:详细步骤+自定义安装+命令行客户端配置(Windows版)
本文详解MySQL 5.7.27的下载、解压、安装、配置及命令行客户端快捷方式创建全流程,涵盖自定义安装、版本选择、root密码设置等关键步骤,适合开发者与学习者快速搭建本地数据库环境。(239字)
|
9月前
|
消息中间件 缓存 监控
MQ消息积压 / Rocketmq 积压 最全的处理方案。 (秒懂+图解+史上最全)
MQ消息积压 / Rocketmq 积压 最全的处理方案。 (秒懂+图解+史上最全)
MQ消息积压 / Rocketmq 积压 最全的处理方案。 (秒懂+图解+史上最全)
|
监控 关系型数据库 MySQL
在Linux中,mysql的innodb如何定位锁问题?
在Linux中,mysql的innodb如何定位锁问题?
|
10月前
|
关系型数据库 MySQL 数据库
MySQL报错:未知系统变量'tx_isolation'及隔离级别查询
记住,选择合适的隔离级别,就像是在风平浪静的湖面上找到适合的划船速度——既要快到能赶上午饭(性能),又不至于翻船(数据一致性问题)。
408 3
|
Java 数据库连接 Spring
Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could
这个错误通常出现在使用Spring Boot进行数据库连接时。错误信息表明Spring Boot未能配置一个DataSource,因为没有指定'url'属性,并且没有发现默认的数据库连接。
6224 0
|
存储 缓存 监控
【JVM调优】如何进行JVM调优?一篇文章就够了!
深入解读JVM性能的监控、定位和调优方案,阐述jps/stat/jstack、MAT等常用性能分析工具的使用,提出JVM参数、内存溢出、内存泄漏、CPU飙升、GC频繁等实际场景下JVM调优的方案。
4447 16
【JVM调优】如何进行JVM调优?一篇文章就够了!
|
Java UED Spring
Springboot通过SSE实现实时消息返回
通过Spring Boot实现SSE,可以简单高效地将实时消息推送给客户端。虽然SSE有其限制,但对于许多实时消息推送场景而言,它提供了一种简洁而强大的解决方案。在实际开发中,根据具体需求选择合适的技术,可以提高系统的性能和用户体验。希望本文能帮助你深入理解Spring Boot中SSE的实现和应用。
7313 1
|
存储 缓存 Java
Spring缓存注解【@Cacheable、@CachePut、@CacheEvict、@Caching、@CacheConfig】使用及注意事项
Spring缓存注解【@Cacheable、@CachePut、@CacheEvict、@Caching、@CacheConfig】使用及注意事项
5023 2

热门文章

最新文章

下一篇
开通oss服务