溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Mysql中Thread Manager的作用是什么

發(fā)布時間:2021-08-04 17:24:25 來源:億速云 閱讀:138 作者:Leah 欄目:數(shù)據(jù)庫

今天就跟大家聊聊有關(guān)Mysql中Thread Manager的作用是什么,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

    1.線程創(chuàng)建函數(shù)

    大家知道,Mysql現(xiàn)在是插件式的存儲引擎,只要實現(xiàn)規(guī)定的接口,就可實現(xiàn)自己的存儲引擎。故Mysql的線程創(chuàng)建除了

出現(xiàn)在主服務(wù)器框架外,存儲引擎也可能會進(jìn)行線程的創(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進(jìn)行事件等待。具體源碼

如下:

result= WaitForMultipleObjects(2, cond->events, FALSE, timeout);

    此處是等待時間,何處進(jìn)行事件通知呢?我們再次來到上篇所提及的為新的連接創(chuàng)建線程的代碼中:

pthread_cond_signal(&COND_thread_cache);

看完上述內(nèi)容,你們對Mysql中Thread Manager的作用是什么有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI