真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MongoDB中查詢超時(shí)異常如何解決

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

10年積累的做網(wǎng)站、網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有吉木薩爾免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

在對超過百萬條記錄的集合進(jìn)行聚合操作。

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);

偶爾會發(fā)生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)

通過多次測試,發(fā)現(xiàn)執(zhí)行一次聚合平均時(shí)間為5s,超過5s時(shí)就會報(bào)錯(cuò)!

然后查看MongoDB的配置信息:

socket-timeout="5000" //5s

socket-timeout的默認(rèn)配置為0,也就是沒有限制。

沒有超時(shí)限制,系統(tǒng)出了問題也不容易發(fā)現(xiàn),應(yīng)該根據(jù)實(shí)際情況,給出合理的超時(shí)時(shí)間。

通過多次測試發(fā)現(xiàn)最長執(zhí)行時(shí)間為6秒,就把超時(shí)時(shí)間設(shè)置成了10000。

socket-timeout="10000" //10s

注意:MongoDB在與Spring整合時(shí),如果要配置多個(gè)MongDB源,只會啟用***一個(gè)配置。

應(yīng)該把參數(shù)配置信息存儲在properties文件中。

  

通過Java API獲取配置參數(shù)

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

***一點(diǎn):  ConnectionTimeOut和SocketTimeOut的區(qū)別:

一次完整的請求包括三個(gè)階段:

  • 建立連接

  • 數(shù)據(jù)傳輸

  • 斷開連接

如果與服務(wù)器(這里指數(shù)據(jù)庫)請求建立連接的時(shí)間超過ConnectionTimeOut,就會拋 ConnectionTimeOutException,即服務(wù)器連接超時(shí),沒有在規(guī)定的時(shí)間內(nèi)建立連接。

如果與服務(wù)器連接成功,就開始數(shù)據(jù)傳輸了。

如果服務(wù)器處理數(shù)據(jù)用時(shí)過長,超過了SocketTimeOut,就會拋出SocketTimeOutExceptin,即服務(wù)器響應(yīng)超時(shí),服務(wù)器沒有在規(guī)定的時(shí)間內(nèi)返回給客戶端數(shù)據(jù)。

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。


當(dāng)前文章:MongoDB中查詢超時(shí)異常如何解決
鏈接地址:http://weahome.cn/article/jpeihs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部