來源: 互聯(lián)網(wǎng)
版本: 不詳, 僅做參考用
初始化:
點(diǎn)擊(此處)折疊或打開
創(chuàng)新互聯(lián)公司長期為上1000+客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為昭通企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站設(shè)計(jì),昭通網(wǎng)站改版等技術(shù)服務(wù)。擁有十年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
-
main
-
|-MySQLd
-
|-my_init // 初始話線程變量,互斥量
-
|-load_defaults // 獲取配置
-
|-init_common_variables // 初始化變量
-
|-init_server_components // 初始化插件
-
| |-plugin_init
-
| | |-plugin_initialize
-
| |-initialize_storage_engine
-
|-network_init // 監(jiān)聽網(wǎng)絡(luò)
-
|-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監(jiān)聽,一個針對網(wǎng)絡(luò),一個針對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); // 已有連接處理線程時,通過信號喚醒,處理線程函數(shù)為pfs_spawn_thread
-
|-mysql_thread_create(啟動的線程執(zhí)行函數(shù),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 // 發(fā)送handshake包到客戶端
-
| | | | |-my_net_write
-
| | | | | |-net_write_buff // 將數(shù)據(jù)寫入到內(nèi)存
-
| | | | |-net_flush // 將內(nèi)存中數(shù)據(jù)發(fā)送到網(wǎng)絡(luò)
-
| | | |-server_mpvio_read_packet // 從客戶端接收Login Request信息
-
| | | |-my_net_read
-
| | |-Protocol::end_statement
-
| | |-Protocol::send_ok
-
| | |-net_send_ok // 發(fā)送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 // 申請表數(shù)據(jù)結(jié)構(gòu)
-
| | |-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
本文名稱:MySQL連接查詢流程源碼
轉(zhuǎn)載源于:http://muchs.cn/article14/ighege.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、網(wǎng)站收錄、ChatGPT、電子商務(wù)、網(wǎng)頁設(shè)計(jì)公司、網(wǎng)站改版
廣告
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源:
創(chuàng)新互聯(lián)