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

最新文章

  1. 【FTP】FTP文件上传下载-支持断点续传
  2. Java学习笔记 04 类和对象
  3. 【转】【WebDriver】不可编辑域和日历控件域的输入 javascript
  4. SQL Server 的通用分页显示存储过程
  5. jq 判断输入数字
  6. 让Windows蓝屏死机
  7. Form( 表单) 组件
  8. Java WebService把Date类型转换成XMLGregorianCalendar
  9. Android_简单笔记一
  10. javascript基础(三)运算
  11. Mongodb 导出json 和csv 格式数据
  12. Python模块学习------ 正则表达式
  13. How to move lobsegment and lobindex to a different Tablespace
  14. Async CallBack promise fetch
  15. Git Pull Github and Gitee or Gitlab
  16. Very very important SQL Server article
  17. PHP接收json格式的POST数据
  18. 单链表LRU
  19. 服务器启动脚本 /etc/rc.local
  20. myeclipse/eclipse安装反编译插件jadclipse

热门文章

  1. pip3的国内安装源
  2. opencv yuvNV21转RGB
  3. JAVA垃圾回收-可达性分析算法
  4. Sublime用正则表达式进行逗号分隔实现列的替换
  5. 【linux基础】Ubuntu16.04桌面突然卡住怎么办?
  6. [LeetCode] 310. Minimum Height Trees 最小高度树
  7. php_mvc实现步骤十
  8. Spring Boot 项目中的 parent
  9. 使用nohup命令编写shell脚本启动java应用,并使用外挂配置文件
  10. python 之 Django框架(ORM常用字段和字段参数、关系字段和和字段参数)