91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MongoDB中查詢超時異常如何解決

發布時間:2021-08-04 14:12:18 來源:億速云 閱讀:307 作者:Leah 欄目:數據庫

MongoDB中查詢超時異常如何解決,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

在對超過百萬條記錄的集合進行聚合操作。

DBObject match=(DBObject)JSON.parse("{$match:{logType:{'$in':[5,9]}}}"); DBObject group=(DBObject)JSON.parse("{$group:{'_id':'$domainUrl','count':{'$sum':1}}}"); AggregationOutput output = logCollection.aggregate(match,group);

偶爾會發生Read timed out 異常。

com.mongodb.MongoException$Network: Read operation to server /192.168.10.202:27017 failed on database adLogTable at com.mongodb.DBTCPConnector.innerCall(DBTCPConnector.java:253) at com.mongodb.DB.command(DB.java:261) at com.mongodb.DB.command(DB.java:243) ... Caused by: java.net.SocketTimeoutException: Read timed out at java.net.SocketInputStream.socketRead0(Native Method) at java.net.SocketInputStream.read(SocketInputStream.java:152)

通過多次測試,發現執行一次聚合平均時間為5s,超過5s時就會報錯!

然后查看MongoDB的配置信息:

socket-timeout="5000" //5s

socket-timeout的默認配置為0,也就是沒有限制。

沒有超時限制,系統出了問題也不容易發現,應該根據實際情況,給出合理的超時時間。

通過多次測試發現最長執行時間為6秒,就把超時時間設置成了10000。

socket-timeout="10000" //10s

注意:MongoDB在與Spring整合時,如果要配置多個MongDB源,只會啟用***一個<mongo:options>配置。

應該把參數配置信息存儲在properties文件中。

<mongo:mongo host="${mongodb.ip}" id="mongo202" port="${mongodb.port}"> <mongo:options connections-per-host="200" threads-allowed-to-block-for-connection-multiplier="100" connect-timeout="1000" max-wait-time="1000" auto-connect-retry="true" socket-keep-alive="true" socket-timeout="10000" slave-ok="true" write-number="1" write-timeout="0" write-fsync="true" /> </mongo:mongo>

通過Java API獲取配置參數

DBCollection logCollection = mongoTemplate.getCollection(collName); MongoOptions mongoOptions = logCollection.getDB().getMongo().getMongoOptions(); System.out.println(mongoOptions.getSocketTimeout());

***一點:  ConnectionTimeOut和SocketTimeOut的區別:

一次完整的請求包括三個階段:

  • 建立連接

  • 數據傳輸

  • 斷開連接

如果與服務器(這里指數據庫)請求建立連接的時間超過ConnectionTimeOut,就會拋 ConnectionTimeOutException,即服務器連接超時,沒有在規定的時間內建立連接。

如果與服務器連接成功,就開始數據傳輸了。

如果服務器處理數據用時過長,超過了SocketTimeOut,就會拋出SocketTimeOutExceptin,即服務器響應超時,服務器沒有在規定的時間內返回給客戶端數據。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

萨迦县| 翁牛特旗| 康定县| 铁力市| 延寿县| 潮州市| 黄石市| 台前县| 仙游县| 云和县| 永靖县| 柯坪县| 徐闻县| 连山| 洪江市| 迁安市| 凤凰县| 宁强县| 北安市| 渝中区| 建始县| 罗江县| 内江市| 房产| 赞皇县| 营口市| 北票市| 承德县| 巴彦淖尔市| 徐汇区| 肇源县| 镇赉县| 绥中县| 错那县| 秭归县| 建德市| 吉林省| 广河县| 永修县| 西吉县| 德清县|