MySQL连接查询流程源码
发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,来源: 互联网版本: 不详, 仅做参考用初始化:点击(此处)折叠或打开main|-mysqld|-my_init // 初始话线程变量,互斥量|-load_defaults // 获取配置|-init
千家信息网最后更新 2025年11月13日MySQL连接查询流程源码来源: 互联网
版本: 不详, 仅做参考用
初始化:
插件启动:
登录过程:
处理连接:
select命令:
版本: 不详, 仅做参考用
初始化:
点击(此处)折叠或打开
- main
- |-mysqld
- |-my_init // 初始话线程变量,互斥量
- |-load_defaults // 获取配置
- |-init_common_variables // 初始化变量
- |-init_server_components // 初始化插件
- | |-plugin_init
- | | |-plugin_initialize
- | |-initialize_storage_engine
- |-network_init // 监听网络
- |-grant_init
- |-servers_init
- |-udf_init
插件启动:
点击(此处)折叠或打开
- main
- |-mysqld_main
- |-init_server_components
- |-plugin_init
- |-plugin_initialize
- |-ha_initialize_handlerton
- |-innobase_init
登录过程:
点击(此处)折叠或打开
- main
- |-mysqld_main
- |-network_init // 建立socket监听,一个针对网络,一个针对unix域
- |-handle_connections_sockets
- |-poll
- |-mysql_socket_accept // 和客户端建立连接
- |-create_new_thread // 针对每个socket连接建立一个新的线程
- |-create_thread_to_handle_connection
- |-waiting_thd_list->push_back(thd);mysql_cond_signal(&COND_thread_cache); // 已有连接处理线程时,通过信号唤醒,处理线程函数为pfs_spawn_thread
- |-mysql_thread_create(启动的线程执行函数,inline_mysql_thread_create)
- |-spawn_thread_v1
- |-pthread_create(pfs_spawn_thread)
处理连接:
点击(此处)折叠或打开
- pfs_spawn_thread
- |-handle_one_connection
- |-do_handle_one_connection
- |-MYSQL_CALLBACK_ELSE(thread_scheduler, init_new_connection_thread, (), 0)
- | |-init_new_connection_handler_thread
- |-thd_prepare_connection
- | |-login_connection // 判断是否可以login,不可以则断开连接返回错误
- | | |-check_connection
- | | | |-acl_authenticate
- | | | |-do_auth_once
- | | | |-native_password_authenticate
- | | | |-server_mpvio_write_packet
- | | | | |-send_server_handshake_packet // 发送handshake包到客户端
- | | | | |-my_net_write
- | | | | | |-net_write_buff // 将数据写入到内存
- | | | | |-net_flush // 将内存中数据发送到网络
- | | | |-server_mpvio_read_packet // 从客户端接收Login Request信息
- | | | |-my_net_read
- | | |-Protocol::end_statement
- | | |-Protocol::send_ok
- | | |-net_send_ok // 发送response ok
- | | |-my_net_write
- | |-prepare_new_connection_state
- |-do_command
- |-dispatch_command
- |-mysql_parse
select命令:
点击(此处)折叠或打开
- pfs_swpawn_thread
- |-handle_one_connection
- |-do_handle_one_connection
- |-do_command
- |-dispatch_command
- |-mysql_parse
- |-parse_sql
- | |-MYSQLparse
- |-mysql_execute_command
- |-select_precheck
- | |-check_table_access
- |-execute_sqlcom_select
- | |-open_normal_and_derived_tables
- | |-open_tables
- | | |-open_and_process_table
- | | |-open_table(THD *thd, TABLE_LIST *table_list, Open_table_context *ot_ctx)
- | | |-Table_cache::get_table
- | | |-get_table_share_with_discover
- | | | |-get_table_share
- | | | |-open_table_def
- | | |-my_malloc // 申请表数据结构
- | | |-open_table_from_share
- | | |-handler::ha_open
- | | |-ha_innobase::open
- | | |-dict_table_open_on_name
- | | |-dict_load_table
- | | |-btr_pcur_is_on_user_rec
- | | |-dict_load_table_low
- | | | |-dict_mem_table_create
- | | |-fil_space_for_table_exists_in_mem
- | | |-fil_open_single_table_tablespace // 打开表空间文件
- | |-mysql_handle_derived
- |-handle_select
- |-mysql_select
- |-mysql_prepare_select
- | |-JOIN::prepare
- |-mysql_execute_select
- |-JOIN::exec
- |-select_send::send_result_set_metadata
- | |-Protocol::send_result_set_metadata
- |-do_select
- |-sub_select
- |-evaluate_join_record
- |-end_send
- |-select_send::send_data
- |-Protocol::write
线程
客户
客户端
数据
网络
处理
内存
函数
变量
插件
监听
互联网
信号
信息
命令
数据结构
文件
来源
版本
申请表
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
智能安全帽数据库
比特币服务器是谁运行的
应急数据库包括哪些
数据库试卷打包
南宁龙猫网络技术有限公司
虹口区专业型数据库反馈
怎么用联通光猫变成服务器
商城app软件开发公司
吉林省鑫泽网络技术有限公
网络安全手抄报写是什么
高程数据如何上传服务器
大专软件开发值得不
服务器 分析
中科曙光计算机网络安全
java数据库编程使用教程
毕马威软件开发怎么样
做网络技术的朋友圈图片
计算机网络安全介绍毕业论文
确保网络安全宣传
飞卢小说为什么连不上服务器
边缘数据库
数据库设置出生日期限制
商城app软件开发公司
nas和小型服务器区别
学籍管理系统数据库课设
近四年来存在的网络安全事件
南京学习软件开发哪家好
数据库技术学院大逃杀
北京文档软件开发常用解决方案
网络安全刘鑫剡答案