thread_cache_size 功能在mysql數(shù)據(jù)庫配置文件中是非常重要的一項功能了,如果對thread_cache_size優(yōu)化做得好我們可以讓服務器跑得非常快,設置不好就會發(fā)現(xiàn)很小訪問量就非常的卡。
MySQL連接除了能通過網(wǎng)絡方式,還可以通過命名管道的方式,不論是哪種方式連接MySQL,在MySQL中都是通過線程的方式管理所有客戶端請求的。每一個客戶端連接都會有一個與之對應的連接線程。
在MySQL中實現(xiàn)了一個Thread Cache池,將空閑的連接線程存放其中,而不是完成請求后就銷毀。這樣當有新的連接請求時,MySQL首先會檢查Thread Cache中是否存在空閑連接線程,如果存在則取出來直接使用,如果沒有空閑連接線程,才創(chuàng)建新的連接線程。
二、線程參數(shù)介紹
具體參數(shù):
Thread_cache_size:ThreadCache池中應該存放的連接線程數(shù)。
查詢Thread_cache_size的配置:
show variables like "thread_cache_size";
Thread_stack:每個連接線程被創(chuàng)建時,MySQL給它分配的內(nèi)存大小。當MySQL創(chuàng)建一個新的連接線程時,需要給它分配一定大小的內(nèi)存堆??臻g,以便存放客戶端的請求的Query及自身的各種狀態(tài)和處理信息。
查看連接線程相關的系統(tǒng)變量的設置值:show variables likethread_cache%;如上圖,系統(tǒng)默認連接線程設置thread_cache_size=64,通過分析計算連接線程池最多將緩存約三十個連接線程左右,每個連接線程創(chuàng)建之初,系統(tǒng)分配一定的內(nèi)存堆棧給這些線程。
查看系統(tǒng)被連接的次數(shù)及當前系統(tǒng)中連接線程的狀態(tài)值:
show status like connections;
show status like %thread%;
如果我們在MySQL服務器配置文件中設置了thread_cache_size,當客戶端斷開之后,服務器處理此客戶的線程將會緩存起來以響應下一個客戶而不是銷毀(前提是緩存數(shù)未達上限)。
Threads_created:表示創(chuàng)建過的線程數(shù),如果發(fā)現(xiàn)Threads_created值過大的話,表明MySQL服務器一直在創(chuàng)建線程,這也是比較耗資源,可以適當增加配置文件中thread_cache_size值。
根據(jù)官網(wǎng)資料和生產(chǎn)實際環(huán)境驗證,如果以上服務器線程緩存thread_cache_size沒有進行設置,或者設置過小,這個值表示可以重新利用保存在緩存中線程的數(shù)量,當斷開連接時如果緩存中還有空間,那么客戶端的線程將被放到緩存中,如果線程重新被請求,那么請求將從緩存中讀取,如果緩存中是空的或者是新的請求,那么這個線程將被重新創(chuàng)建,如果有很多新的線程,增加這個值可以改善系統(tǒng)性能,通過比較Connections 和Threads_created 狀態(tài)的變量,可以看到這個變量的作用。(“--->?”表示要調(diào)整的值) 根據(jù)物理內(nèi)存設置規(guī)則如下:
系統(tǒng)啟動到現(xiàn)在共接受到客戶端的連接10246394次,共創(chuàng)建了2766個連接線程,當前有8個連接線程處于和客戶端連接的狀態(tài),而49個連接狀態(tài)的線程中只有一個處于active 狀態(tài),即只有一個正在處理客戶端提交的請求,而在ThreadCache池中共緩存了49個連接線程。
Thread Cache 命中率:
Thread_Cache_Hit = (Connections - Threads_created) / Connections *100%;一般在系統(tǒng)穩(wěn)定運行一段時間后,ThreadCache命中率應該保持在90%左右才算正常。
實際應用:
針對16G/32G的機器,一般設置512K夠用了,當然如果遇到下面的錯誤提示就應該考慮增加這個值。
如果是短連接,適當設置大一點,因為短連接往往需要不停創(chuàng)建,不停銷毀,如果大一點,連接線程都處于取用狀態(tài),不需要重新創(chuàng)建和銷毀,所以對性能肯定是比較大的提升。
對于長連接,不能保證連接的穩(wěn)定性,所以設置這參數(shù)還是有一定必要,可能連接池的問題,會導致連接數(shù)據(jù)庫的不穩(wěn)定性,也會出現(xiàn)頻繁的創(chuàng)建和銷毀,但這個情況比較少,如果是長連接,可以設置成小一點,一般在50-100左右。
根據(jù)業(yè)務側(cè)后臺java程序進行數(shù)據(jù)處理時,thread_stack報錯提示進行分析,并提供解決方法如下。
官方相關thread_stack的信息分析:
The default (192KB) is large enough for normal operation. If thethread stack size is too small, it limits the complexity of the SQLstatements that the server can handle, the recursion depth of storedprocedures, and other memory-consuming actions.
根據(jù)官方對該參數(shù)的信息分析如下:
Thread Stack默認值(192KB)足夠正常運行。如果線程堆棧大小太小,則會限制服務器可以處理的SQL語句的復雜性,存儲過程的遞歸深度以及其他消耗內(nèi)存的操作??梢允褂胹howvariables where `variable_name` =“thread_stack”;查詢當前數(shù)據(jù)庫的默認線程棧的大小,一般情況下都能正常使用,但是當查詢語句或者存儲過程復雜時會報Threadstack overrun(超限)錯誤,此時只要修改增加默認配置就可以了。
解決方法:
在數(shù)據(jù)庫中修改配置文件my.cnf只有這個文件才能生效,然后重啟服務數(shù)據(jù)庫。
[mysqld]
thread_stack = 512k
thread_cache_size = 64
重啟數(shù)據(jù)庫之后:
通過以上處理方式,根據(jù)業(yè)務側(cè)后臺java程序調(diào)取數(shù)據(jù)過程中發(fā)生thread_stack報錯,進行調(diào)優(yōu),然后通知業(yè)務側(cè)重新開啟java程序數(shù)據(jù)處理目前一切正常。
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/130042.html
摘要:顯示處于不可中斷的休眠的進程數(shù)量。我們可以實用內(nèi)存數(shù)據(jù)庫,替代他的功能。 MySQL對于很多Linux從業(yè)者而言,是一個非常棘手的問題,多數(shù)情況都是因為對數(shù)據(jù)庫出現(xiàn)問題的情況和處理思路不清晰。在進行MySQL的優(yōu)化之前必須要了解的就是MySQL的查詢過程,很多的查詢優(yōu)化工作實際上就是遵循一些原則讓MySQL的優(yōu)化器能夠按照預想的合理方式運行而已。 showImg(https://seg...
摘要:請注意,我們在聊聊單元測試遇到問題多思考多查閱多驗證,方能有所得,再勤快點樂于分享,才能寫出好文章。單元測試是指對軟件中的最小可測試單元進行檢查和驗證。 JAVA容器-自問自答學HashMap 這次我和大家一起學習HashMap,HashMap我們在工作中經(jīng)常會使用,而且面試中也很頻繁會問到,因為它里面蘊含著很多知識點,可以很好的考察個人基礎。但一個這么重要的東西,我為什么沒有在一開始...
摘要:基礎問題的的性能及原理之區(qū)別詳解備忘筆記深入理解流水線抽象關鍵字修飾符知識點總結(jié)必看篇中的關鍵字解析回調(diào)機制解讀抽象類與三大特征時間和時間戳的相互轉(zhuǎn)換為什么要使用內(nèi)部類對象鎖和類鎖的區(qū)別,,優(yōu)缺點及比較提高篇八詳解內(nèi)部類單例模式和 Java基礎問題 String的+的性能及原理 java之yield(),sleep(),wait()區(qū)別詳解-備忘筆記 深入理解Java Stream流水...
閱讀 1356·2023-01-11 13:20
閱讀 1707·2023-01-11 13:20
閱讀 1215·2023-01-11 13:20
閱讀 1906·2023-01-11 13:20
閱讀 4165·2023-01-11 13:20
閱讀 2757·2023-01-11 13:20
閱讀 1402·2023-01-11 13:20
閱讀 3671·2023-01-11 13:20