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树,后续请求只需执行而无需重复解析。
➡️