時(shí)間:2024-02-08 11:17作者:下載吧人氣:28
在公司的項(xiàng)目中,突然出現(xiàn)過一個(gè)情況,mongodb 的CPU利用率到達(dá)100%,導(dǎo)致服務(wù)器這邊卡死了,請(qǐng)求了半天無響應(yīng),提示請(qǐng)求超時(shí)。
因?yàn)椋?dāng)時(shí)APP用戶可能會(huì)在某一個(gè)時(shí)間段集中的使用,所以,請(qǐng)求量一下子就飆上去了,剛好APP打開請(qǐng)求的時(shí)候,有一個(gè)mongodb的請(qǐng)求。
當(dāng)時(shí)因?yàn)镸ongodb的服務(wù)器不在我們這邊,所以一下子沒反應(yīng)過來,不過最后還是給排除出,并解決了。這里就來記錄下排查和解決的全過程。
問題分析:
1.根據(jù)代碼,定位到了是Mongodb的報(bào)錯(cuò)。
2.進(jìn)入Mongodb 服務(wù)器的監(jiān)控后臺(tái),這里是在阿里云購買的云緩存。
3.知道是Mongodb出問題,就好辦了,阿里云里面有個(gè)索引推薦,很好用的,會(huì)給出查詢時(shí)間,執(zhí)行次數(shù),和推薦策略
OK,這里準(zhǔn)備工作就基本做完了。
解決策略:
1.根據(jù)這些給出的執(zhí)行次數(shù),和執(zhí)行時(shí)間慢的,去看了下庫。從設(shè)計(jì)上,有問題,一個(gè)庫有900W的數(shù)據(jù),然后集合邏輯看了下,這庫只往里面存數(shù)據(jù),從不清理
2.沒有建立過索引,包括單一索引和連接索引,這也是會(huì)導(dǎo)致慢的一個(gè)原因。優(yōu)化后是這樣的,
db.getCollection(‘course_study_history’).createIndex({‘studentId’:1,’contentStudyID’:1,’courseWareID’:1,’courseStudyId’:1})
3.一個(gè)查詢總數(shù)的方法有問題,下面是修改后的JAVA方法:
MongoCollection<Document> collection = database.getCollection(pushMessageCollection); long cNt = collection.count(Filters.and(Filters.eq("userId", userId), Filters.eq("sendType", sendType), Filters.eq("message_read", "0")));
網(wǎng)友評(píng)論