Reading TiDB Source Code (Part 1): Overview of Service Listening and Request Processing Flow

💡 原文英文,约2600词,阅读约需10分钟。
📝

内容提要

本文概述了TiDB的请求处理流程,从main函数开始,分析了服务监听、连接建立、握手、SQL解析、逻辑优化和物理执行等步骤,并提到预编译语句的性能优势,因其避免了重复编译和优化。

🎯

关键要点

  • TiDB的请求处理流程从main函数开始,涉及服务监听、连接建立、握手等步骤。
  • 在s.startNetworkListener中,使用for循环接受连接并开启goroutine处理。
  • onConn函数中进行握手并标记连接状态,随后进入cc.dispatch函数处理请求。
  • dispatch函数根据命令类型处理不同的SQL请求,主要包括ComQuery和预编译语句的处理。
  • handleQuery函数执行SQL查询并返回结果集,执行时间对TiDB性能至关重要。
  • 预编译语句性能更好,因为它避免了重复编译和优化,只需传递数据。
  • TiDB的执行过程包括建立连接、握手、处理请求、解析SQL、逻辑优化和物理执行。
  • 物理执行引擎通过Executor接口实现,支持Open-Next-Close协议。
  • 预编译语句通过Prepare方法解析AST树,后续请求只需执行而无需重复解析。
➡️

继续阅读