今天就跟大家聊聊有關(guān)MySQL中Thread Manager的作用是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
10年積累的網(wǎng)站設(shè)計制作、成都做網(wǎng)站經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有花都免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
1.線程創(chuàng)建函數(shù)
大家知道,Mysql現(xiàn)在是插件式的存儲引擎,只要實現(xiàn)規(guī)定的接口,就可實現(xiàn)自己的存儲引擎。故Mysql的線程創(chuàng)建除了
出現(xiàn)在主服務(wù)器框架外,存儲引擎也可能會進行線程的創(chuàng)建。通過設(shè)置斷點,在我調(diào)試的版本中,發(fā)現(xiàn)了兩個創(chuàng)建線程的函數(shù)。
os_thread_create是存儲引擎innobase的線程函數(shù),先擱淺不研究了,重點看下pthread_create,首先看下其源碼。
map->func=func; map->param=param;
hThread=(HANDLE)_beginthread((void( __cdecl *)(void *)) pthread_start, attr->dwStackSize ? attr->dwStackSize : 65535, (void*) map);
上面代碼首先構(gòu)造了一個map結(jié)構(gòu)體,成員分別是函數(shù)地址和傳入?yún)?shù)。然后調(diào)用操作系統(tǒng)的接口,_beginthread,但是執(zhí)行函數(shù)并不是傳入的函數(shù)——func,而是pthread_start,參數(shù)為map。繼續(xù)跟蹤pthread_start。
func=((struct pthread_map *) param)->func
可以看出,pthread_start中調(diào)用了map的func元素,作為真正執(zhí)行的函數(shù)體。OK,創(chuàng)建線程的函數(shù)跟蹤到此!
2.服務(wù)器啟動時創(chuàng)建了哪些函數(shù)?
通過在兩個創(chuàng)建線程的地方設(shè)置斷點,總結(jié)了下,在服務(wù)器啟動時,創(chuàng)建了如下的線程。
pthread_create創(chuàng)建的線程:
innobase的os_thread_create創(chuàng)建的線程:
還可以在調(diào)試過程中,通過暫停來看此時服務(wù)器中的線程,如下圖:
三、線程緩沖池
Mysql支持線程緩存,在多線程連接模式下,如果連接斷開后,將這個線程放入空閑線程緩沖區(qū),在下次有連接到來時,
先去緩沖池中查找是否有空閑線程,有則用之,無則創(chuàng)建。啟動時可以設(shè)置線程緩沖池的數(shù)目:
在一個連接斷開時,會調(diào)用cache_thread函數(shù),將空閑的線程加入到cache中,以備后用。如下:
cached_thread_count < thread_cache_size
pthread_cond_signal(&COND_flush_thread_cache);
上面我們的啟動參數(shù)設(shè)置線程緩沖區(qū)為10,此時對應(yīng)代碼里面的thread_cache_size = 10,cached_thread_count記錄
了此刻cache中的空閑線程數(shù)目,只有在cache未滿的情況下,才會將新的空閑線程加入緩沖池中。加入到緩沖區(qū)其實就是將線
程掛起,pthread_cond_wait函數(shù)便是線程等待函數(shù),在此函數(shù)中,會調(diào)用WaitForMultipleObjects進行事件等待。具體源碼
如下:
result= WaitForMultipleObjects(2, cond->events, FALSE, timeout);
此處是等待時間,何處進行事件通知呢?我們再次來到上篇所提及的為新的連接創(chuàng)建線程的代碼中:
pthread_cond_signal(&COND_thread_cache);
看完上述內(nèi)容,你們對Mysql中Thread Manager的作用是什么有進一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。
網(wǎng)站欄目:Mysql中ThreadManager的作用是什么
轉(zhuǎn)載來于:http://www.rwnh.cn/article8/jiscip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、用戶體驗、靜態(tài)網(wǎng)站、企業(yè)建站、商城網(wǎng)站、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)