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)!
#

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于架构原理的相关内容,MySQL Server架构自顶向下大致可以分网络连接层、服务层、存储引擎层和系统文件层,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

mysql的msi与zip版本的区别:1、zip包含的安装程序是一种主动安装,而msi包含的是被installer所用的安装文件以提交请求的方式安装;2、zip是一种数据压缩和文档存储的文件格式,msi是微软格式的安装包。

方法:1、利用right函数,语法为“update 表名 set 指定字段 = right(指定字段, length(指定字段)-1)...”;2、利用substring函数,语法为“select substring(指定字段,2)..”。

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

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

SublimeText3漢化版
中文版,非常好用

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Dreamweaver Mac版
視覺化網頁開發工具