簡體   English   中英

MySql-客戶端超時

[英]MySql - client timed out

我正在使用C3P0(0.9.5.2)連接池連接到MySQL DB。 我已將默認語句超時設置為1秒。 我看到在高負載期間,盡管未達到最大池容量,但某些連接請求超時( checkoutTimeout為1秒)。 在分析線程堆棧時,我看到“ MySQL Cancellation timer”線程處於可運行狀態。 可能存在大量超時,這導致數據庫無響應,並且在1秒內未創建新連接。

有沒有一種方法可以最大程度地減少取消計時器的影響,並確保在未達到最大池容量的情況下不會發生客戶端超時?

即使池不是maxPoolSize ,如果設置了checkoutTimeout並且無法在超時時間內獲取新的連接,則嘗試maxPoolSize也會超時。 checkoutTimeout只是一個超時,無論原因如何,都會強制執行時間限制。

如果要防止超時,則必須確保可以在指定的時間內使連接可用。 如果某種原因使數據庫對連接請求無響應,則最直接的解決方案顯然是解決該問題。 其他方法可能包括設置更大的acquireIncrement (以便更可能預取連接)或更大的minPoolSize (相同)。

或者,您可以選擇更長的超時時間(或完全不設置超時)。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM