MySQL连接查询流程源码
发表于:2024-11-15 作者:千家信息网编辑
千家信息网最后更新 2024年11月15日,来源: 互联网版本: 不详, 仅做参考用初始化:点击(此处)折叠或打开main|-mysqld|-my_init // 初始话线程变量,互斥量|-load_defaults // 获取配置|-init
千家信息网最后更新 2024年11月15日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安全错误
数据库的锁怎样保障安全
网络技术应用选修三课件
黄州司翰网络技术有限公司
网络安全与管理a
小学生网络安全测试题
软件开发职业要求
任务管理器无法连接到服务器
视屏网站 数据库
相片调色软件开发
软件开发方案 百度文库
深圳卖家联盟网络技术有限公司
正版视频聊天软件开发
对计算机网络技术的了解与认识
文件服务器群集
基于构件软件开发方法的缺点
学习网络安全专家
长春电商软件开发公司排名
双静网络技术
计算机软件开发工作好找吗
互联网掩盖了科技停滞
管家婆辉煌版局域网访问服务器
哪个网站可以承接软件开发
网络安全法44条罚款
网络安全技术岗位设置
几年前的软件开发票有盘吗
万网独立服务器
璧山区咨询软件开发服务常见问题
初中网络安全教育二维码
高中网络安全教育ppt免费
校园招聘系统数据库管理
元宇宙与网络技术