http://blog.itpub.net/29510932/viewspace-2129300/

初始化:

点击(此处)折叠或打开

  1. main
  2. |-mysqld
  3. |-my_init // 初始话线程变量,互斥量
  4. |-load_defaults // 获取配置
  5. |-init_common_variables // 初始化变量
  6. |-init_server_components // 初始化插件
  7. | |-plugin_init
  8. | | |-plugin_initialize
  9. | |-initialize_storage_engine
  10. |-network_init // 监听网络
  11. |-grant_init
  12. |-servers_init
  13. |-udf_init

插件启动:

点击(此处)折叠或打开

  1. main
  2. |-mysqld_main
  3. |-init_server_components
  4. |-plugin_init
  5. |-plugin_initialize
  6. |-ha_initialize_handlerton
  7. |-innobase_init

登录过程:

点击(此处)折叠或打开

  1. main
  2. |-mysqld_main
  3. |-network_init // 建立socket监听,一个针对网络,一个针对unix域
  4. |-handle_connections_sockets
  5. |-poll
  6. |-mysql_socket_accept // 和客户端建立连接
  7. |-create_new_thread // 针对每个socket连接建立一个新的线程
  8. |-create_thread_to_handle_connection
  9. |-waiting_thd_list->push_back(thd);mysql_cond_signal(&COND_thread_cache); // 已有连接处理线程时,通过信号唤醒,处理线程函数为pfs_spawn_thread
  10. |-mysql_thread_create(启动的线程执行函数,inline_mysql_thread_create)
  11. |-spawn_thread_v1
  12. |-pthread_create(pfs_spawn_thread)

处理连接:

点击(此处)折叠或打开

  1. pfs_spawn_thread
  2. |-handle_one_connection
  3. |-do_handle_one_connection
  4. |-MYSQL_CALLBACK_ELSE(thread_scheduler, init_new_connection_thread, (), 0)
  5. | |-init_new_connection_handler_thread
  6. |-thd_prepare_connection
  7. | |-login_connection // 判断是否可以login,不可以则断开连接返回错误
  8. | | |-check_connection
  9. | | | |-acl_authenticate
  10. | | | |-do_auth_once
  11. | | | |-native_password_authenticate
  12. | | | |-server_mpvio_write_packet
  13. | | | | |-send_server_handshake_packet // 发送handshake包到客户端
  14. | | | | |-my_net_write
  15. | | | | | |-net_write_buff // 将数据写入到内存
  16. | | | | |-net_flush // 将内存中数据发送到网络
  17. | | | |-server_mpvio_read_packet // 从客户端接收Login Request信息
  18. | | | |-my_net_read
  19. | | |-Protocol::end_statement
  20. | | |-Protocol::send_ok
  21. | | |-net_send_ok // 发送response ok
  22. | | |-my_net_write
  23. | |-prepare_new_connection_state
  24. |-do_command
  25. |-dispatch_command
  26. |-mysql_parse

select命令:

点击(此处)折叠或打开

  1. pfs_swpawn_thread
  2. |-handle_one_connection
  3. |-do_handle_one_connection
  4. |-do_command
  5. |-dispatch_command
  6. |-mysql_parse
  7. |-parse_sql
  8. | |-MYSQLparse
  9. |-mysql_execute_command
  10. |-select_precheck
  11. | |-check_table_access
  12. |-execute_sqlcom_select
  13. | |-open_normal_and_derived_tables
  14. | |-open_tables
  15. | | |-open_and_process_table
  16. | | |-open_table(THD *thd, TABLE_LIST *table_list, Open_table_context *ot_ctx)
  17. | | |-Table_cache::get_table
  18. | | |-get_table_share_with_discover
  19. | | | |-get_table_share
  20. | | | |-open_table_def
  21. | | |-my_malloc // 申请表数据结构
  22. | | |-open_table_from_share
  23. | | |-handler::ha_open
  24. | | |-ha_innobase::open
  25. | | |-dict_table_open_on_name
  26. | | |-dict_load_table
  27. | | |-btr_pcur_is_on_user_rec
  28. | | |-dict_load_table_low
  29. | | | |-dict_mem_table_create
  30. | | |-fil_space_for_table_exists_in_mem
  31. | | |-fil_open_single_table_tablespace // 打开表空间文件
  32. | |-mysql_handle_derived
  33. |-handle_select
  34. |-mysql_select
  35. |-mysql_prepare_select
  36. | |-JOIN::prepare
  37. |-mysql_execute_select
  38. |-JOIN::exec
  39. |-select_send::send_result_set_metadata
  40. | |-Protocol::send_result_set_metadata
  41. |-do_select
  42. |-sub_select
  43. |-evaluate_join_record
  44. |-end_send
  45. |-select_send::send_data
  46. |-Protocol::write

MySQL连接查询流程源码的更多相关文章

  1. [Android]Android系统启动流程源码分析

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5013863.html Android系统启动流程源码分析 首先 ...

  2. 转:InnoDB Crash Recovery 流程源码实现分析

    此文章转载给登博的文章,给大家分享 InnoDB Crash Recovery 流程源码实现分析 Crash Recovery问题 本文主要分析了InnoDB整个crash recovery的源码处理 ...

  3. Spark(五十一):Spark On YARN(Yarn-Cluster模式)启动流程源码分析(二)

    上篇<Spark(四十九):Spark On YARN启动流程源码分析(一)>我们讲到启动SparkContext初始化,ApplicationMaster启动资源中,讲解的内容明显不完整 ...

  4. 【图解源码】Zookeeper3.7源码分析,包含服务启动流程源码、网络通信源码、RequestProcessor处理请求源码

    Zookeeper3.7源码剖析 能力目标 能基于Maven导入最新版Zookeeper源码 能说出Zookeeper单机启动流程 理解Zookeeper默认通信中4个线程的作用 掌握Zookeepe ...

  5. Netty 学习(五):服务端启动核心流程源码说明

    Netty 学习(五):服务端启动核心流程源码说明 作者: Grey 原文地址: 博客园:Netty 学习(五):服务端启动核心流程源码说明 CSDN:Netty 学习(五):服务端启动核心流程源码说 ...

  6. [Android]从Launcher开始启动App流程源码分析

    以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/5017056.html 从Launcher开始启动App流程源码 ...

  7. mysql连接查询经典小例题

    mysql连接查询: Mysql连接查询支持多表连接 对同一张表可以重复连接多次(别名在多次连接同一张表时很重要) 例题1: 下面有2张表 teams表 比赛结果表:result 问题: 得出一张表: ...

  8. Spring加载流程源码分析03【refresh】

      前面两篇文章分析了super(this)和setConfigLocations(configLocations)的源代码,本文来分析下refresh的源码, Spring加载流程源码分析01[su ...

  9. Android Activity启动流程源码全解析(1)

    前言 Activity是Android四大组件的老大,我们对它的生命周期方法调用顺序都烂熟于心了,可是这些生命周期方法到底是怎么调用的呢?在启动它的时候会用到startActivty这个方法,但是这个 ...

随机推荐

  1. ROS tf-深入Time和TF

    博客转载自:https://www.ncnynl.com/archives/201702/1313.html ROS与C++入门教程-tf-深入Time和TF 说明: 介绍使用waitForTrans ...

  2. jxls:用jx:if实现字典值格式化

    用JXLS导出excel非常方便,但是我们往往需要把字典值转为中文名称,例如1转为男,这个时候就需要用到jx:if来完成. 请见下图: jx:if(condition="obj.way==1 ...

  3. 【非lodop的】JS和html相关博文索引

    JS: eval()方法:JS-JAVASCRIPT的eval()方法. Date()对象.getFullYear() 方法.getDate()方法.console.dir()方法:LODOP打印用J ...

  4. Excel统计发票和金税盘核对新版

    之前的博文:如何使用Excel表格状态栏动态查看统计,介绍了如何利用excel一拉就可以进行统计,和金税盘的月度统计统计.由于最近年月日显示成方框,所以作废了发票和对冲了上月的一张发票,导致这个月出现 ...

  5. 【linux基础】ubuntu实现双屏显示

    前言 之前博主没有使用NVIDIA时候已经可以实现双屏显示(拼接类型),但是,安装NVIDIA驱动使用CUDA之后这个功能就消失了,需要重新配置. 实现方式 1. 使用Intel集成显卡时实现双屏拼接 ...

  6. [LeetCode] 128. Longest Consecutive Sequence 求最长连续序列

    Given an unsorted array of integers, find the length of the longest consecutive elements sequence. F ...

  7. 简单的Lock死锁例子

    static void Main(string[] args) { lock (_lock1) { var t = new Thread(() => { lock (_lock1) { Cons ...

  8. Spring中的乱码问题

    最近发现一个问题, 中文编码保存到数据库里显示正确, 打印出来却是一串问号, 然后怀疑是平台默认编码的问题, locale命令显示是UTF-8正常, 然后单独编写一个java文件, 编译然后Java命 ...

  9. 【转帖】处理器史话 | 这张漫画告诉你,为什么双核CPU能打败四核CPU?

    处理器史话 | 这张漫画告诉你,为什么双核CPU能打败四核CPU? https://www.eefocus.com/mcu-dsp/371324 2016-10-28 10:28 作者:付丽华预计 9 ...

  10. easyui_datagrid实现导出Excel

    easyui_datagrid实现导出Excel 一.PHPExcel使用方法 先下载PHPExcel类库文件,并引入. 二.利用AJAX实现datagrid导出Excel 原理:前台通过AJAX调用 ...