mysql 鏈接超時的幾個參數詳解

mysql5.7版本中,先查看超時設置參數,我們這里只關注需要的超時參數,并不是全都講解

show variables like '%timeout%';

connect_timeout

指的是連接過程中握手的超時時間,在5.0.52以后默認為10秒,之前版本默認是5秒,主要是客戶端的參數。

mysql的基本原理應該是有個監聽線程循環接收請求,當有請求來時,創建線程(或者從線程池中取)來處理這
請求。由于mysql連接采用TCP協議,那么之前勢必是需要進行TCP三次握手的。
TCP三次握手成功之后,客戶端進入阻塞,等待服務端的消息。服務端這個時候會創建一個線程(或者從線程池中取一個線程)來處理請求,主要驗證部分包括host和用戶名密碼驗證。host驗證我們比較熟悉,因為在用grant命令授權用戶的時候是有指定host的。
用戶名密碼認證則是服務端先生成一個隨機數發送給客戶端,客戶端用該隨機數和密碼進行多次sha1加密后發送給服務端驗證。如果通過,整個連接握手過程完成

wait_timeout(interactive_timeout)

從文檔上來看wait_timeout和interactive_timeout都是指不活躍的連接超時時間,連接線程啟動的時候wait_timeout會根據是交互模式還是非交互模式被設置為這兩個值中的一個,默認是8個小時。

數據庫重啟數據庫空閑連接超過設置的最大timemout時間導致數據庫會強行斷開已有的鏈接,就會報這個異常。
如果在wait_timeout秒期間內,數據庫連接(java.sql.Connection)一直處于等待狀態,mysql就將該連接關閉。這時,你的Java應用的連接池仍然合法地持有該連接的引用。當用該連接來進行數據庫操作時,就會產生上述錯誤。一般mysql自身連接的等待時間(wait_timeout)缺省為8小時,或者通過命令參數查看

net_read_timeout 和 net_write_timeout

net_read_timeoutmysql服務端從客戶端讀取(接收)數據時,服務端等待客戶端響應的超時時間,當服務端正在從客戶端讀取?數據時,net_read_timeout控制何時超時。對于這個參數,session和global級別并沒有什么特別,session級別只對當前連接生效,global級別只對新?的連接生效。默認值是30S。net_write_timeoutmysql服務端向客戶端寫(發送)數據時,服務端等待客戶端響應的超時時間,當服務端正在寫數據到客戶端?時,net_write_timeout控制何時超時。對于這個參數,session和global級別并沒有什么特別,session級別只對當前連接生效,global級別只對新?的連接生效,默認值是60S。

參考文檔:

mysql 5.7 連接超時參數設置_mysql connecttimeout-CSDN博客

數據庫連接池連接超時報錯 - 知乎

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/208868.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/208868.shtml
英文地址,請注明出處:http://en.pswp.cn/news/208868.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【vscode寫vue代碼是白色怎么辦】

【vscode寫vue代碼是白色怎么辦】 在插件列表中搜索Vetur 安裝即可

Web學習路線

閱讀前請看一下:我是一個熱衷于記錄的人,每次寫博客會反復研讀,盡量不斷提升博客質量。文章設置為僅粉絲可見,是因為寫博客確實花了不少精力。希望互相進步謝謝!! 文章目錄 閱讀前請看一下:我是…

Redis 命令全解析之 Hash類型

文章目錄 ?介紹?命令?RedisTemplate API?應用場景 ?介紹 Hash類型,也叫散列,其value是一個無序字典,類似于Java中的 HashMap 結構。 String結構是將對象序列化為JSON字符串后存儲,當需要修改對象某個字段時很不方便&#xf…

降維技術——PCA、LCA 和 SVD

一、說明 降維在數據分析和機器學習中發揮著關鍵作用,為高維數據集帶來的挑戰提供了戰略解決方案。隨著數據集規模和復雜性的增長,特征或維度的數量通常變得難以處理,導致計算需求增加、潛在的過度擬合和模型可解釋性降低。降維技術通過捕獲數…

用隊列實現棧

問題描述: 請你僅用兩個隊列實現一個后入先出(LIFO)的棧,并支持普通隊列的全部四種操作(push、top、pop和empty)。 實現MyStack類: void push(int x) 將元素x壓入棧頂。int pop()移除并返回棧頂…

java中線程的狀態是如何轉換的?

在 Java 中,線程有幾種狀態,主要包括 NEW(新建)、RUNNABLE(可運行)、BLOCKED(阻塞)、WAITING(等待)、TIMED_WAITING(計時等待)、和 TE…

Vue學習筆記-Vue3中的計算屬性與監視屬性

computed函數 import {reactive,computed} from vue export default {name: "DemoVue",setup(){//數據定義let person reactive({firstName : 李,lastName : 四,age:18,})//計算屬性定義-簡寫形式person.fullName computed(()>{return person.firstName-person…

手寫 Promise:深入理解異步編程的基石

手寫 Promise:深入理解異步編程的基石 本文將帶您逐步實現一個簡單的 Promise,以幫助您深入理解異步編程的基本概念。通過自己動手編寫 Promise 的過程,您將更好地理解 Promise 的工作原理和常見用法,并能夠應用于實際項目中。 …

什么是網站劫持

網站劫持是一種網絡安全威脅,它通過非法訪問或篡改網站的內容來獲取機密信息或者破壞計算機系統。如果您遇到了網站劫持問題,建議您立即聯系相關的安全機構或者技術支持團隊,以獲得更專業的幫助和解決方案。

探索 HTTPS:保障網絡通信的安全性

引言 HTTPS(HyperText Transfer Protocol Secure)是一種安全的通信協議,用于在網絡上安全地傳輸數據。它是基于 HTTP 協議的擴展,通過加密通信實現了數據的保護和安全性。 功能介紹 加密數據傳輸: 使用加密技術對數…

Prism框架快速注冊帶有特性標簽的類型

前言 最近用Prims框架,真的是懶得手動注冊各種類型,不利于團隊開發工作,各種dll強耦合,后期維護還麻煩,這次我們帶來了一個快速注冊的類來快速提高開發效率。重點用到的就是通過反射出dll里面的類型,然后根據特性或者類型過濾來完成快速注冊的功能。 代碼 using Prism…

Angular 進階之四:SSR 應用場景與局限

應用場景 內容豐富,復雜交互的動態網頁,對首屏加載有要求的項目,對 seo 有要求的項目(因為服務端第一次渲染的時候,已經把關鍵字和標題渲染到響應的 html 中了,爬蟲能夠抓取到此靜態內容,因此更…

【面試專題】MySQL篇①

1.MySQL中,如何定位慢查詢? ①介紹一下當時產生問題的場景(我們當時的一個接口測試的時候非常的慢,壓測的結果大概5秒鐘) ②我們系統中當時采用了運維工具( Skywalking ),可以監測出哪個接口…

PostgreSQL從小白到高手教程 - 第38講:數據庫備份

PostgreSQL從小白到專家,是從入門逐漸能力提升的一個系列教程,內容包括對PG基礎的認知、包括安裝使用、包括角色權限、包括維護管理、、等內容,希望對熱愛PG、學習PG的同學們有幫助,歡迎持續關注CUUG PG技術大講堂。 第38講&#…

running小程序重要技術流程文檔

一、項目文件說明: (注:getMyMoney無用已刪除) 二、重要文件介紹 1.reinfo.js:位于utils文件下,該文件封裝有統一的請求URL,和請求API同意封裝供頁面調用;調用時候需要在頁面上先…

【C語言】操作符詳解(一):進制轉換,原碼,反碼,補碼

目錄 操作符分類 2進制和進制轉換 2進制轉10進制 10進制轉2進制 2進制轉8進制和16進制 2進制轉8進制 2進制轉16進制 原碼、反碼、補碼 操作符分類 操作符中有一些操作符和二進制有關系,我們先鋪墊一下二進制的和進制轉換的知識。 2進制和進制轉換 其實我們經…

數據結構準備知識

struct(結構體) struct,或稱為結構體,是C語言中一種復合數據類型,它允許你將多個不同類型的數據項組合成一個單一的單位。這對于創建記錄或更復雜的數據結構非常有用。 結構體的定義語法如下: struct 結…

vertica主鍵列能插入重復值的處理辦法

問題描述 開發同事反饋在vertica中創建含主鍵列的表中插入重復數據時沒有進行校驗,插入重復值成功。經過測試著實可以插入重復值,這個坑有些不一樣。 創建表和插入語句如下: --創建表 CREATE TABLE dhhtest(ID VARCHAR(64) PRIMARY KEY );…

postgresql數據庫配置主從并配置ssl加密

1、先將postgresql數據庫主從配置好 參考:postgresql主從配置 2、在主節點配置ssl加密,使用navicat測試是否可以連接 參考:postgresql配置ssl 3、正常連接無誤后,將root.crt、server.crt、server.key復制到從數據庫節點的存儲…

使用Microsoft Dynamics AX 2012 - 5. 生產控制

生產控制的主要職責是生產成品。為了完成這項任務,制造業需要消耗物品和資源能力(人員和機械)。制造過程可能包括半成品的生產和庫存。半成品是指物品包括在成品材料清單中。 制造業的業務流程 根據公司的要求,您可以選擇申請Dy…