搜尋
首頁資料庫mysql教程MySQL伺服器連線過程分析

mysqld是MySQL伺服器端主進程,可以說mysqld是MySQL的真正核心,一切工作都是圍繞著mysqld進程進行的。所以要解剖mysql這個龐然大物,mysqld的程式碼是最好的突破口。

一切都是從熟悉的main()函數開始的,其實是從mysqld_main()函數開始的。這些程式碼都在mysqld.cc。 mysqld_main()隨後呼叫了win_main)()。 win_main()函數主要是做了一些初始化的工作。

初始化工作完成之後,MySQL已經準備好接受連線了。然後我們的主角Handle_connections_methods()函數登場了。這個函數的主要工作是新建3個子進程,他們分別接受TCP/IP、命名管道以及共享記憶體這三種方式的連接。一般情況下客戶都是用TCP/IP(socket)來連接MySQL伺服器的,這是最有彈性的通訊方式。但是在嵌入式軟體的應用環境中,需要採用後兩種通訊方式。

  • 簡化後的handle_connections_methods()函數:

  • ##
    static void handle_connections_methods()
    {
      mysql_mutex_lock(&LOCK_thread_count);
      mysql_cond_init(key_COND_handler_count, &COND_handler_count, NULL);
      handler_count=0;
      handler_count++;
      mysql_thread_create(key_thread_handle_con_namedpipes, &hThread, &connection_attrib, handle_connections_namedpipes, 0));
      handler_count++;
      mysql_thread_create(key_thread_handle_con_sockets, &hThread, &connection_attrib, handle_connections_sockets_thread, 0));
      handler_count++;
      mysql_thread_create(key_thread_handle_con_sharedmem, &hThread, &connection_attrib, handle_connections_shared_memory, 0))
      while (handler_count > 0)
        mysql_cond_wait(&COND_handler_count, &LOCK_thread_count);
      mysql_mutex_unlock(&LOCK_thread_count);
    }
新建了3個執行緒之後,handle_connectins_methods()函數進入一個長時間循環,直到3個連線線程全部退出後才退出。這裡我主要看看socket的連結線程,我們的研究對象就是這個handle_connections_sockets_thread。這個線程把自己初始化之後,就直接調用了handle_connections_sockets();

handle_connections_sockets()函數使用select()呼叫監聽mysqld的端口,然後等待客戶端的連接。等到一個客戶端連接後,這個函數中會新建一個THD類型的變量,這個變量是一個“交際花”,從連接建立開始,到SQL語法分析、查詢執行、結果返回等等。這個變數一直都在,總之這是一個非常重要的變數。

還有struct st_vio這個結構體,這個結構體是一個指令的中轉站。在「交際花」THD中也定義了一個vio類型的結構體。這個結構體的功能就是從儲存從套接字中讀取通訊內容,然後又把自己的值賦給THD的vio變數。 VIO類型中詳細的描述了一次請求,包括請求的內容、時間、請求的套接字位址等等。之後發生的事情就是把這個「交際花」傳遞到服務線程,create_thread_to_handle_connection()實作這個功能。

  • 以下是刪減後的程式碼

  • void create_thread_to_handle_connection(THD *thd)
    {
      if (cached_thread_count > wake_thread)
      {
        mysql_cond_signal(&COND_thread_cache);
      }
      else
      {
        mysql_thread_create(key_thread_one_connection, &thd->real_id, &connection_attrib, handle_one_connection, (void*) thd)));    
      }
    }
這個函數會查看有沒有閒置的快取執行緒(MySQL不會把斷開連接後的服務線程立即銷毀掉,而是緩存了起來),如果有就是用緩存線程,如果沒有就新建一個線程來服務連接。至此,一個連線就進入了服務線程,連接線程返回繼續等待連線。

後邊的內容都是在服務線程中實現的,《深入理解MySQL》中有很詳細的程式碼追蹤,有興趣的同學可以看看。我把函數呼叫順序附上,供參考。

handle_one_connection()
mysql_thread_create()
handle_one_connection()
do_handle_one_connection()
init_new_connection_thread()
init_new_connection_handler_thread()
do_command()
dispatch_command()
mysql_parse()
mysql_execuate_command()

以上就是MySQL伺服器連線過程分析的內容,更多相關內容請關注PHP中文網(www.php.cn)!

#

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
解釋InnoDB緩衝池及其對性能的重要性。解釋InnoDB緩衝池及其對性能的重要性。Apr 19, 2025 am 12:24 AM

InnoDBBufferPool通過緩存數據和索引頁來減少磁盤I/O,提升數據庫性能。其工作原理包括:1.數據讀取:從BufferPool中讀取數據;2.數據寫入:修改數據後寫入BufferPool並定期刷新到磁盤;3.緩存管理:使用LRU算法管理緩存頁;4.預讀機制:提前加載相鄰數據頁。通過調整BufferPool大小和使用多個實例,可以優化數據庫性能。

MySQL與其他編程語言:一種比較MySQL與其他編程語言:一種比較Apr 19, 2025 am 12:22 AM

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。MySQL以其高性能、可扩展性和跨平台支持著称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

學習MySQL:新用戶的分步指南學習MySQL:新用戶的分步指南Apr 19, 2025 am 12:19 AM

MySQL值得學習,因為它是強大的開源數據庫管理系統,適用於數據存儲、管理和分析。 1)MySQL是關係型數據庫,使用SQL操作數據,適合結構化數據管理。 2)SQL語言是與MySQL交互的關鍵,支持CRUD操作。 3)MySQL的工作原理包括客戶端/服務器架構、存儲引擎和查詢優化器。 4)基本用法包括創建數據庫和表,高級用法涉及使用JOIN連接表。 5)常見錯誤包括語法錯誤和權限問題,調試技巧包括檢查語法和使用EXPLAIN命令。 6)性能優化涉及使用索引、優化SQL語句和定期維護數據庫。

MySQL:初學者的基本技能MySQL:初學者的基本技能Apr 18, 2025 am 12:24 AM

MySQL適合初學者學習數據庫技能。 1.安裝MySQL服務器和客戶端工具。 2.理解基本SQL查詢,如SELECT。 3.掌握數據操作:創建表、插入、更新、刪除數據。 4.學習高級技巧:子查詢和窗口函數。 5.調試和優化:檢查語法、使用索引、避免SELECT*,並使用LIMIT。

MySQL:結構化數據和關係數據庫MySQL:結構化數據和關係數據庫Apr 18, 2025 am 12:22 AM

MySQL通過表結構和SQL查詢高效管理結構化數據,並通過外鍵實現表間關係。 1.創建表時定義數據格式和類型。 2.使用外鍵建立表間關係。 3.通過索引和查詢優化提高性能。 4.定期備份和監控數據庫確保數據安全和性能優化。

MySQL:解釋的關鍵功能和功能MySQL:解釋的關鍵功能和功能Apr 18, 2025 am 12:17 AM

MySQL是一個開源的關係型數據庫管理系統,廣泛應用於Web開發。它的關鍵特性包括:1.支持多種存儲引擎,如InnoDB和MyISAM,適用於不同場景;2.提供主從復制功能,利於負載均衡和數據備份;3.通過查詢優化和索引使用提高查詢效率。

SQL的目的:與MySQL數據庫進行交互SQL的目的:與MySQL數據庫進行交互Apr 18, 2025 am 12:12 AM

SQL用於與MySQL數據庫交互,實現數據的增、刪、改、查及數據庫設計。 1)SQL通過SELECT、INSERT、UPDATE、DELETE語句進行數據操作;2)使用CREATE、ALTER、DROP語句進行數據庫設計和管理;3)複雜查詢和數據分析通過SQL實現,提升業務決策效率。

初學者的MySQL:開始數據庫管理初學者的MySQL:開始數據庫管理Apr 18, 2025 am 12:10 AM

MySQL的基本操作包括創建數據庫、表格,及使用SQL進行數據的CRUD操作。 1.創建數據庫:CREATEDATABASEmy_first_db;2.創建表格:CREATETABLEbooks(idINTAUTO_INCREMENTPRIMARYKEY,titleVARCHAR(100)NOTNULL,authorVARCHAR(100)NOTNULL,published_yearINT);3.插入數據:INSERTINTObooks(title,author,published_year)VA

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器