欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL數(shù)據(jù)庫超時設置配置的方法實例

 更新時間:2021年10月13日 10:18:03   作者:張松然  
這篇文章主要給大家介紹了關于MySQL數(shù)據(jù)庫超時設置配置的相關資料,通過文中的設置方法可以很好的解決大家遇到的mysql數(shù)據(jù)庫超時問題,需要的朋友可以參考下

前言

最近備戰(zhàn)京東雙11,在配置MySQL的超時配置發(fā)現(xiàn)有很多地方可以設置。這么多超時的配置有什么影響,以及配置會有什么影響呢?今天的文章就讓我來大家來分析一下。

1. JDBC超時設置

connectTimeout:表示等待和MySQL數(shù)據(jù)庫建立socket鏈接的超時時間,默認值0,表示不設置超時,單位毫秒,建議30000

socketTimeout:表示客戶端和MySQL數(shù)據(jù)庫建立socket后,讀寫socket時的等待的超時時間,linux系統(tǒng)默認的socketTimeout為30分鐘,可以不設置

2. 連接池超時設置

maxWait:表示從數(shù)據(jù)庫連接池取鏈接,連接池沒有可用連接時的等待時間,默認值0,表示無限等待,單位毫秒,建議60000

3. MyBatis查詢超時

defaultStatementTimeout:表示在MyBatis配置文件中默認查詢超時間,單位秒,不設置則無線等待

如果一些sql需要執(zhí)行超過defaultStatementTimeout可以通過Mapper文件單獨的sql的timeout進行配置

4. 事務超時

事務超時用于控制事務執(zhí)行的超時,執(zhí)行時間是事務內所有代碼執(zhí)行總和,單位為秒。

總結

高級別的timeout依賴于低級別的timeout,只有當?shù)图墑e的timeout無誤時,高級別的timeout才能確保正常。例如,當socket timeout出現(xiàn)問題時,高級別的statement timeout和transaction timeout都將失效。

1. Transaction Timeout

Spring提供的transaction timeout配置非常簡單,它會記錄每個事務的開始時間和消耗時間,當特定的事件發(fā)生時就會對消耗時間做校驗,當超出timeout值時將拋出異常。

假設某個事務中包含5個statement,每個statement的執(zhí)行時間是200ms,其他業(yè)務邏輯的執(zhí)行時間是100ms,那么transaction timeout至少應該設置為1,100ms(200 * 5 + 100)。

2. Statement Timeout

statement timeout用來限制statement的執(zhí)行時長,timeout的值通過調用JDBC的java.sql.Statement.setQueryTimeout(int timeout) API進行設置。不過現(xiàn)在開發(fā)者已經很少直接在代碼中設置,而多是通過框架來進行設置。

在iBatis中,statement timeout的默認值可以通過sql-map-config.xml中的defaultStatementTimeout 屬性進行設置。同時,你還可以設置sqlmap中select,insert,update標簽的timeout屬性,從而對不同sql語句的超時時間進行獨立的配置。

3. Socket timeout

JDBC的socket timeout在數(shù)據(jù)庫被突然停掉或是發(fā)生網絡錯誤(由于設備故障等原因)時十分重要。由于TCP/IP的結構原因,socket沒有辦法探測到網絡錯誤,因此應用也無法主動發(fā)現(xiàn)數(shù)據(jù)庫連接斷開。如果沒有設置socket timeout的話,應用在數(shù)據(jù)庫返回結果前會無期限地等下去,這種連接被稱為dead connection。

為了避免dead connections,socket必須要有超時配置。socket timeout可以通過JDBC設置,socket timeout能夠避免應用在發(fā)生網絡錯誤時產生無休止等待的情況,縮短服務失效的時間。

不推薦使用socket timeout來限制statement的執(zhí)行時長,因此socket timeout的值必須要高于statement timeout,否則,socket timeout將會先生效,這樣statement timeout就變得毫無意義,也無法生效。

到此這篇關于MySQL數(shù)據(jù)庫超時設置配置的文章就介紹到這了,更多相關MySQL數(shù)據(jù)庫超時設置配置內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MySQL解決Navicat設置默認字符串時的報錯問題

    MySQL解決Navicat設置默認字符串時的報錯問題

    本文主要介紹了MySQL解決Navicat設置默認字符串時的報錯,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • Windows平臺下MySQL安裝與配置方法與注意事項

    Windows平臺下MySQL安裝與配置方法與注意事項

    這篇文章主要介紹了Windows平臺下MySQL安裝與配置方法與注意事項,需要的朋友可以參考下
    2017-04-04
  • 詳解Mysql之mysqlbackup備份與恢復實踐

    詳解Mysql之mysqlbackup備份與恢復實踐

    這篇文章主要介紹了詳解Mysql之mysqlbackup備份與恢復實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • mysql 找回誤刪表的數(shù)據(jù)方法(必看)

    mysql 找回誤刪表的數(shù)據(jù)方法(必看)

    下面小編就為大家?guī)硪黄猰ysql 找回誤刪表的數(shù)據(jù)方法(必看)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-03-03
  • mysql關于or的索引的問題及解決

    mysql關于or的索引的問題及解決

    這篇文章主要介紹了mysql關于or的索引的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL數(shù)據(jù)庫的約束限制詳解

    MySQL數(shù)據(jù)庫的約束限制詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)庫的約束限制詳解,數(shù)據(jù)庫的約束是對表中數(shù)據(jù)進行的一種限制,為了保證數(shù)據(jù)的正確性、有效性、完整性,下文簡單介紹需要的朋友可以參考一下
    2022-08-08
  • mysql的docker容器如何設置默認的數(shù)據(jù)庫技巧詳解

    mysql的docker容器如何設置默認的數(shù)據(jù)庫技巧詳解

    這篇文章主要為大家介紹了mysql的docker容器如何設置默認的數(shù)據(jù)庫技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • MySql 字符串中提取數(shù)字的實現(xiàn)示例

    MySql 字符串中提取數(shù)字的實現(xiàn)示例

    在MySQL中,有時需要從字符串中提取數(shù)字,本文就來介紹一下MySql 字符串中提取數(shù)字的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下
    2023-09-09
  • pymysql操作mysql數(shù)據(jù)庫的方法

    pymysql操作mysql數(shù)據(jù)庫的方法

    這篇文章主要介紹了pymysql簡單操作mysql數(shù)據(jù)庫的方法,主要講的是一些基礎的pymysql操作mysql數(shù)據(jù)庫的方法,結合實例代碼給大家講解的非常詳細,需要的朋友可以參考下
    2023-04-04
  • 分享MySql8.0.19 安裝采坑記錄

    分享MySql8.0.19 安裝采坑記錄

    這篇文章主要介紹了MySql8.0.19 安裝采坑記錄,內容雖然不長,但是都是朋友經常遇到的問題,小編特此分享到腳本之家平臺,需要的朋友可以參考下
    2020-02-02

最新評論