成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

數(shù)據(jù)庫連接配置策略和實(shí)踐指南

運(yùn)維 數(shù)據(jù)庫運(yùn)維
應(yīng)用執(zhí)行SQL請求完成的過程中,數(shù)據(jù)庫連接占很重要一部分。尤其是涉及到流量瞬間暴漲,需要?jiǎng)?chuàng)建大量連接,或者網(wǎng)絡(luò)異常導(dǎo)致重連時(shí),從業(yè)務(wù)端來看,sql執(zhí)行緩慢的問題,此時(shí)sql執(zhí)行并非真的慢。

一 前言

應(yīng)用執(zhí)行SQL請求完成的過程中,數(shù)據(jù)庫連接占很重要一部分。尤其是涉及到流量瞬間暴漲,需要?jiǎng)?chuàng)建大量連接,或者網(wǎng)絡(luò)異常導(dǎo)致重連時(shí),從業(yè)務(wù)端來看,sql執(zhí)行緩慢的問題,此時(shí)sql執(zhí)行并非真的慢。本文是基于我們自己的生產(chǎn)環(huán)境的Durid實(shí)踐,僅供各位參考,當(dāng)然不同公司的鏈路/業(yè)務(wù)壓力可能不一樣。具體到個(gè)別參數(shù)需要區(qū)別對待。

[[281409]]

二 具體實(shí)踐

從整體系統(tǒng)的角度,我們要考慮幾個(gè)點(diǎn) ,數(shù)據(jù)庫連接數(shù)配置多少合適,針對空閑連接,網(wǎng)絡(luò)異常的超時(shí)時(shí)間,如何高效復(fù)用連接,druid 版本選擇這幾個(gè)方面來介紹。

2.1 如何設(shè)置連接池大小

合適的連接池大小和業(yè)務(wù)請求的 QPS 和 單個(gè)請求的 RT(單位為毫秒)。基本公式:

連接數(shù) = QPS /(1000/RT) + N = QPS * RT /1000 + N

注意: 此處 QPS 和 RT 為單個(gè)應(yīng)用端統(tǒng)計(jì)。假定隨連接數(shù)量增加,客戶端能處理的請求數(shù)線性增加。

舉個(gè)例子

  1. 比如 一個(gè)請求的耗時(shí)rt=2ms,每個(gè)連接能處理的請求數(shù)量  
  2. S = 1000/2 =500 ,  
  3. 業(yè)務(wù)層總請求量是 M=5000 ,那么合理的連接數(shù)為 
  4. M/S=5000/500=10 
  5. 為了避免連接數(shù)被占滿,我們會在上面的連接數(shù)的基礎(chǔ)上再加上N ,最終的連接數(shù)為10+N . 

統(tǒng)計(jì)平時(shí)的最大 QPS 和此時(shí)的 RT,以此計(jì)算 minIdle,并設(shè)置 initialSize = minIdle。

統(tǒng)計(jì)峰值時(shí)的 QPS 和此時(shí)的 RT,以此計(jì)算 maxActive。

可以通過以下方法,通過 jmx 觀察 Druid 實(shí)際的連接池狀況,重點(diǎn)關(guān)注 ActiveCount:活動連接數(shù),PoolingCount:池子中的連接數(shù)。并根據(jù)實(shí)際情況考慮調(diào)整。

  1. java -XX:+UseConcMarkSweepGC -XX:+CMSClassUnloadingEnabled -XX:+TieredCompilation -XX:TieredStopAtLevel=1 -Xverify:none -client -jar /PATH/cmdline-jmxclient-0.10.3.jar - 127.0.0.1:7777 'com.alibaba.druid:type=DruidDataSourceStat' DataSourceList |& grep -E 'ActiveCount|PoolingCount' 

2.2 如何設(shè)置超時(shí)時(shí)間

連接池中的超時(shí)時(shí)間主要有:

  • connectTimeout 建立 TCP 連接的超時(shí)時(shí)間
  • maxWait 從連接池獲取連接的最長等待時(shí)間
  • socketTimeout 發(fā)送請求后等待響應(yīng)的超時(shí)時(shí)間

其中,connectTimeout 建議不要小于 1200ms。TCP 在建立連接時(shí),SYN 包的超時(shí)重傳時(shí)間為 1s。connectTimeout 設(shè)置過短,很可能造成應(yīng)用發(fā)布時(shí),初始化連接池過程中由于網(wǎng)絡(luò)抖動,或中間網(wǎng)絡(luò)設(shè)備需要初始化狀態(tài)發(fā)生丟包觸發(fā)超時(shí),從而造成連接池初始化失敗而導(dǎo)致發(fā)布失敗。

socketTimeout 可以根據(jù)應(yīng)用最長的查詢返回時(shí)間設(shè)置。過長會造成生網(wǎng)絡(luò)問題,或數(shù)據(jù)庫服務(wù)有問題時(shí)雪崩;過短也會造成頻繁請求超時(shí)。不要短于 300ms。TCP 的最小 RTO 為 200ms,并根據(jù)延遲動態(tài)調(diào)整。過短的超時(shí)時(shí)間會造成單個(gè)丟包就造成請求超時(shí)。生產(chǎn)環(huán)境數(shù)據(jù)庫都配置有 SQL Killer,會自動殺死執(zhí)行時(shí)間過長的請求。因此,設(shè)置過長的 socketTimeout 也是沒有意義的。

maxWait 可以根據(jù)應(yīng)用期待的等待時(shí)間設(shè)置。為避免在發(fā)生網(wǎng)絡(luò)問題,或數(shù)據(jù)庫服務(wù)有問題時(shí)雪崩,這個(gè)時(shí)間設(shè)置不要過大。下面的默認(rèn)值 800ms 是個(gè)保守的設(shè)置。應(yīng)用可以設(shè)置一個(gè)更短的時(shí)間,如 300ms。過短的時(shí)間也會造成在連接池中連接數(shù)不足,需要新建連接時(shí)造成大量超時(shí)。建議不要低于 100ms。

2.3 如何設(shè)置連接保持時(shí)間

設(shè)置連接保持活躍的時(shí)間需要考慮是直連還是通過數(shù)據(jù)庫中間件proxy連接。一般現(xiàn)在的生產(chǎn)環(huán)境大多為:

  1. App -> LVS -> Proxy -> DB 

其中應(yīng)用到 RDS 的訪問路徑為 App -> LVS -> Proxy 。

其中,LVS 空閑連接保留時(shí)間為 90s。Proxy 為了避免訪問到已被關(guān)閉的連接,自身的空閑連接保留時(shí)間為 [70, 85) s。因此,應(yīng)用程序?yàn)榱吮苊鈴倪B接池獲取到已被關(guān)閉的連接,應(yīng)當(dāng)設(shè)置自身保留空閑連接時(shí)間不能超過70s。打開KeepAlive之后的效果

  • 初始化連接池時(shí)會填充到minIdle數(shù)量。
  • 連接池中的minIdle數(shù)量以內(nèi)的連接,空閑時(shí)間超過
  • minEvictableIdleTimeMillis,則會執(zhí)行keepAlive操作。
  • 當(dāng)網(wǎng)絡(luò)斷開等原因產(chǎn)生的由ExceptionSorter檢測出來的死連接被清除后,自動補(bǔ)充連接到minIdle數(shù)量。
  1. timeBetweenEvictionRunsMillis=10000,  
  2. minEvictableIdleTimeMillis=44000,  
  3. maxEvictableIdleTimeMillis=55000。 

2.4 必選配置項(xiàng)

以下默認(rèn)配置可以根據(jù)實(shí)際情況調(diào)整。

  1. <bean id="cartDataSource" class="com.alibaba.druid.pool.DruidDataSource" 
  2.  
  3. init-method="init" destroy-method="close"
  4.  
  5. <property name="url" value="${cluster.jdbc.url}"/> 
  6.  
  7. <property name="username" value="${cluster.jdbc.username}"/> 
  8.  
  9. <property name="password" value="${cluster.jdbc.password}"/> 
  10.  
  11. <property name="connectionInitSqls" value="set names utf8mb4"/> 
  12.  
  13. <!-- 連接池初始連接數(shù) --> 
  14.  
  15. <property name="initialSize" value="5" /> 
  16.  
  17. <!-- 允許的最大同時(shí)使用中(在被業(yè)務(wù)線程持有,還沒有歸還給druid) 的連接數(shù) --> 
  18.  
  19. <property name="maxActive" value="20" /> 
  20.  
  21. <!-- 允許的最小空閑連接數(shù),空閑連接超時(shí)踢除過程會最少保留的連接數(shù) --> 
  22.  
  23. <property name="minIdle" value="5" /> 
  24.  
  25. <!-- 從連接池獲取連接的最大等待時(shí)間 800毫秒;業(yè)務(wù)方根據(jù)可以自行調(diào)整--> 
  26.  
  27. <property name="maxWait" value="800" /> 
  28.  
  29. <!-- 一條物理連接的最大存活時(shí)間 120分鐘--> 
  30.  
  31. <property name="phyTimeoutMillis" value="7200000"/> 
  32.  
  33. <!-- 強(qiáng)行關(guān)閉從連接池獲取而長時(shí)間未歸還給druid的連接(認(rèn)為異常連接)--> 
  34.  
  35. <property name="removeAbandoned" value="true"/> 
  36.  
  37. <!-- 異常連接判斷條件,超過180 秒 則認(rèn)為是異常的,需要強(qiáng)行關(guān)閉 --> 
  38.  
  39. <property name="removeAbandonedTimeout" value="180"/> 
  40.  
  41. <!-- 從連接池獲取到連接后,如果超過被空閑剔除周期,是否做一次連接有效性檢查 --> 
  42.  
  43. <property name="testWhileIdle" value="true"/> 
  44.  
  45. <!-- 從連接池獲取連接后,是否馬上執(zhí)行一次檢查 --> 
  46.  
  47. <property name="testOnBorrow" value="false"/> 
  48.  
  49. <!-- 歸還連接到連接池時(shí)是否馬上做一次檢查 --> 
  50.  
  51. <property name="testOnReturn" value="false"/> 
  52.  
  53. <!-- 連接有效性檢查的SQL --> 
  54.  
  55. <property name="validationQuery" value="SELECT 1"/> 
  56.  
  57. <!-- 連接有效性檢查的超時(shí)時(shí)間 1 秒 --> 
  58.  
  59. <property name="validationQueryTimeout" value="1"/> 
  60.  
  61. <!-- 周期性剔除長時(shí)間呆在池子里未被使用的空閑連接, 10秒一次--> 
  62.  
  63. <property name="timeBetweenEvictionRunsMillis" value="10000"/> 
  64.  
  65. <!-- 空閑多久可以認(rèn)為是空閑太長而需要剔除 44 秒--> 
  66.  
  67. <property name="minEvictableIdleTimeMillis" value="44000"/> 
  68.  
  69. <!-- 如果空閑時(shí)間太長即使連接池所剩連接 < minIdle 也會被剔除 55 秒 --> 
  70.  
  71. <property name="maxEvictableIdleTimeMillis" value="55000"/> 
  72.  
  73. <!-- 是否設(shè)置自動提交,相當(dāng)于每個(gè)語句一個(gè)事務(wù) --> 
  74.  
  75. <property name="defaultAutoCommit" value="true"/> 
  76.  
  77. <!-- 記錄被判定為異常的連接 --> 
  78.  
  79. <property name="logAbandoned" value="true"/> 
  80.  
  81. <!-- 網(wǎng)絡(luò)讀取超時(shí),網(wǎng)絡(luò)連接超時(shí) 
  82.  
  83. socketTimeout : 對于線上業(yè)務(wù)小于5s,對于BI等執(zhí)行時(shí)間較長的業(yè)務(wù)的SQL,需要設(shè)置大一點(diǎn) 
  84.  
  85. --> 
  86.  
  87. <property name="connectionProperties" value="socketTimeout=3000;connectTimeout=1200"/> 
  88.  
  89. <property name="proxyFilters"
  90.  
  91. <list> 
  92.  
  93. <ref bean="log-filter"/> 
  94.  
  95. </list> 
  96.  
  97. </property> 
  98.  
  99. </bean> 

1.0.28版本之后,新加入keepAlive配置,缺省關(guān)閉。使用keepAlive功能,建議使用1.1.16或者更高版本。一般業(yè)務(wù)無需打開,除非分鐘請求量在個(gè)位數(shù)或者啟動時(shí)間超長導(dǎo)致初始連接都過期。

2.5 druid版本

建議使用最新版本,不要使用太老的版本,以免遇到 bug。

e.g. Maven 配置:

  1. <dependency> 
  2.      
  3. <groupId>com.alibaba</groupId> 
  4.      
  5. <artifactId>druid</artifactId> 
  6.      
  7. <version>1.0.27</version> 
  8.    
  9. </dependency> 

三 小結(jié)

本文算是數(shù)據(jù)庫連接池配置(案例及排查指南) 的一個(gè)補(bǔ)充,希望對需要關(guān)注數(shù)據(jù)庫連接配置的朋友有所幫助。

 

責(zé)任編輯:武曉燕 來源: 服務(wù)端思維
相關(guān)推薦

2023-09-12 09:45:54

Java數(shù)據(jù)庫

2021-11-01 05:54:01

數(shù)據(jù)庫安全信息安全網(wǎng)絡(luò)攻擊

2024-05-08 08:37:44

2023-04-27 09:36:43

2025-01-22 08:19:34

2023-07-24 09:00:00

數(shù)據(jù)庫

2023-07-06 15:05:34

矢量數(shù)據(jù)庫數(shù)據(jù)庫

2009-03-19 10:08:09

C#數(shù)據(jù)庫查詢

2022-06-29 11:01:17

K8s數(shù)據(jù)庫Cassandra

2011-07-04 09:12:53

數(shù)據(jù)庫采購

2011-07-05 10:16:16

Qt 數(shù)據(jù)庫 SQLite

2023-12-28 08:00:00

數(shù)據(jù)庫人工智能

2011-04-01 12:32:37

aspaccess數(shù)據(jù)庫

2009-07-20 13:31:50

Ruby on Rai

2021-03-02 08:00:00

項(xiàng)目管理組織工具

2009-06-16 09:25:31

JBoss配置

2010-08-10 15:02:18

Oracle認(rèn)證數(shù)據(jù)庫

2022-09-01 07:23:53

云原生數(shù)據(jù)庫Aurora

2021-04-09 08:21:25

數(shù)據(jù)庫索引數(shù)據(jù)

2011-03-25 09:05:02

Oracle數(shù)據(jù)庫共享連接專用連接
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日本人做爰大片免费观看一老师 | 欧美aⅴ | 日韩在线观看网站 | 91精品在线播放 | 天天操天天怕 | 一级毛片大全免费播放 | 精品毛片 | 孕妇一级毛片 | 欧美一区二区三区日韩 | 欧美精品黄 | 在线免费观看黄色av | 欧美日韩久久久 | 午夜精品久久久久久久 | 成人免费视频网站在线观看 | 亚洲午夜精品视频 | 日本一道本视频 | 国产成人综合在线 | 福利视频一区二区 | 欧美一区二区在线观看视频 | 亚洲成人精品久久久 | 欧美日韩综合一区 | 国产激情网站 | 亚洲免费精品 | 国产999精品久久久久久 | 国产一级免费在线观看 | 又爽又黄axxx片免费观看 | 黄色免费在线观看网址 | 两性午夜视频 | 91精品久久久久久久久99蜜臂 | 国产一区二区影院 | 99精品国产一区二区三区 | 久久国产免费 | 久久99深爱久久99精品 | 日韩成人在线免费观看 | 婷婷色网 | 成人做爰www免费看视频网站 | 国产精品久久久久久一区二区三区 | 中文字幕亚洲区 | 精品久久国产老人久久综合 | 玩丰满女领导对白露脸hd | 成人av网站在线观看 |