作者:張松然
最近備戰(zhàn)京東雙11,在配置MySQL的超時(shí)配置發(fā)現(xiàn)有很多地方可以設(shè)置。這么多超時(shí)的配置有什么影響,以及配置會有什么影響呢?今天的文章就讓我來大家來分析一下。
1. JDBC超時(shí)設(shè)置
connectTimeout:表示等待和MySQL數(shù)據(jù)庫建立socket鏈接的超時(shí)時(shí)間,默認(rèn)值0,表示不設(shè)置超時(shí),單位毫秒,建議30000
socketTimeout:表示客戶端和MySQL數(shù)據(jù)庫建立socket后,讀寫socket時(shí)的等待的超時(shí)時(shí)間,linux系統(tǒng)默認(rèn)的socketTimeout為30分鐘,可以不設(shè)置
2. 連接池超時(shí)設(shè)置
maxWait:表示從數(shù)據(jù)庫連接池取鏈接,連接池沒有可用連接時(shí)的等待時(shí)間,默認(rèn)值0,表示無限等待,單位毫秒,建議60000
3. MyBatis查詢超時(shí)
defaultStatementTimeout:表示在MyBatis配置文件中默認(rèn)查詢超時(shí)間,單位秒,不設(shè)置則無線等待
如果一些sql需要執(zhí)行超過defaultStatementTimeout可以通過Mapper文件單獨(dú)的sql的timeout進(jìn)行配置
4. 事務(wù)超時(shí)
事務(wù)超時(shí)用于控制事務(wù)執(zhí)行的超時(shí),執(zhí)行時(shí)間是事務(wù)內(nèi)所有代碼執(zhí)行總和,單位為秒。
總結(jié)
高級別的timeout依賴于低級別的timeout,只有當(dāng)?shù)图墑e的timeout無誤時(shí),高級別的timeout才能確保正常。例如,當(dāng)socket timeout出現(xiàn)問題時(shí),高級別的statement timeout和transaction timeout都將失效。
1. Transaction Timeout
Spring提供的transaction timeout配置非常簡單,它會記錄每個(gè)事務(wù)的開始時(shí)間和消耗時(shí)間,當(dāng)特定的事件發(fā)生時(shí)就會對消耗時(shí)間做校驗(yàn),當(dāng)超出timeout值時(shí)將拋出異常。
假設(shè)某個(gè)事務(wù)中包含5個(gè)statement,每個(gè)statement的執(zhí)行時(shí)間是200ms,其他業(yè)務(wù)邏輯的執(zhí)行時(shí)間是100ms,那么transaction timeout至少應(yīng)該設(shè)置為1,100ms(200 * 5 + 100)。
2.?Statement Timeout
statement timeout用來限制statement的執(zhí)行時(shí)長,timeout的值通過調(diào)用JDBC的java.sql.Statement.setQueryTimeout(int timeout) API進(jìn)行設(shè)置。不過現(xiàn)在開發(fā)者已經(jīng)很少直接在代碼中設(shè)置,而多是通過框架來進(jìn)行設(shè)置。
在iBatis中,statement timeout的默認(rèn)值可以通過sql-map-config.xml中的defaultStatementTimeout 屬性進(jìn)行設(shè)置。同時(shí),你還可以設(shè)置sqlmap中select,insert,update標(biāo)簽的timeout屬性,從而對不同sql語句的超時(shí)時(shí)間進(jìn)行獨(dú)立的配置。
3.?Socket timeout
JDBC的socket timeout在數(shù)據(jù)庫被突然停掉或是發(fā)生網(wǎng)絡(luò)錯(cuò)誤(由于設(shè)備故障等原因)時(shí)十分重要。由于TCP/IP的結(jié)構(gòu)原因,socket沒有辦法探測到網(wǎng)絡(luò)錯(cuò)誤,因此應(yīng)用也無法主動發(fā)現(xiàn)數(shù)據(jù)庫連接斷開。如果沒有設(shè)置socket timeout的話,應(yīng)用在數(shù)據(jù)庫返回結(jié)果前會無期限地等下去,這種連接被稱為dead connection。
為了避免dead connections,socket必須要有超時(shí)配置。socket timeout可以通過JDBC設(shè)置,socket timeout能夠避免應(yīng)用在發(fā)生網(wǎng)絡(luò)錯(cuò)誤時(shí)產(chǎn)生無休止等待的情況,縮短服務(wù)失效的時(shí)間。
不推薦使用socket timeout來限制statement的執(zhí)行時(shí)長,因此socket timeout的值必須要高于statement timeout,否則,socket timeout將會先生效,這樣statement timeout就變得毫無意義,也無法生效。
- 第九屆華為ICT大賽中國總決賽收官 84支隊(duì)伍晉級全球總決賽
- 聯(lián)想集團(tuán)黃建恒:SSG業(yè)務(wù)已連續(xù)15個(gè)季度雙位數(shù)增長
- 聯(lián)想集團(tuán)ISG總裁:已將多款暢銷服務(wù)器進(jìn)行升級
- 全球超大規(guī)模數(shù)據(jù)中心數(shù)量五年翻倍,2024年新增137個(gè)!
- 華為楊超斌:行業(yè)智能化是開啟產(chǎn)業(yè)新紀(jì)元的磅礴引擎
- 華為郭振興:2025年行業(yè)數(shù)智化將呈現(xiàn)五大特征
- 加速行業(yè)智能化!華為攜手伙伴共筑解決方案競爭力,共贏時(shí)代新機(jī)遇
- 華為李鵬:AI正深刻改變每一個(gè)行業(yè),攜手伙伴共贏全面智能化時(shí)代
- 華為汪濤:全面推進(jìn)“全面智能化”戰(zhàn)略,發(fā)展伙伴“同路人”共贏智能未來
- 因聚而生,眾智有為:華為中國合作伙伴大會2025圓滿舉行
免責(zé)聲明:本網(wǎng)站內(nèi)容主要來自原創(chuàng)、合作伙伴供稿和第三方自媒體作者投稿,凡在本網(wǎng)站出現(xiàn)的信息,均僅供參考。本網(wǎng)站將盡力確保所提供信息的準(zhǔn)確性及可靠性,但不保證有關(guān)資料的準(zhǔn)確性及可靠性,讀者在使用前請進(jìn)一步核實(shí),并對任何自主決定的行為負(fù)責(zé)。本網(wǎng)站對有關(guān)資料所引致的錯(cuò)誤、不確或遺漏,概不負(fù)任何法律責(zé)任。任何單位或個(gè)人認(rèn)為本網(wǎng)站中的網(wǎng)頁或鏈接內(nèi)容可能涉嫌侵犯其知識產(chǎn)權(quán)或存在不實(shí)內(nèi)容時(shí),應(yīng)及時(shí)向本網(wǎng)站提出書面權(quán)利通知或不實(shí)情況說明,并提供身份證明、權(quán)屬證明及詳細(xì)侵權(quán)或不實(shí)情況證明。本網(wǎng)站在收到上述法律文件后,將會依法盡快聯(lián)系相關(guān)文章源頭核實(shí),溝通刪除相關(guān)內(nèi)容或斷開相關(guān)鏈接。