欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MongoDb CPU利用率過(guò)高問(wèn)題如何解決

 更新時(shí)間:2020年09月22日 12:06:28   作者:手撕高達(dá)的村長(zhǎng)  
這篇文章主要介紹了MongoDb CPU利用率過(guò)高問(wèn)題如何解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

在公司的項(xiàng)目中,突然出現(xiàn)過(guò)一個(gè)情況,mongodb 的CPU利用率到達(dá)100%,導(dǎo)致服務(wù)器這邊卡死了,請(qǐng)求了半天無(wú)響應(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)過(guò)來(lái),不過(guò)最后還是給排除出,并解決了。這里就來(lái)記錄下排查和解決的全過(guò)程。

問(wèn)題分析:

1.根據(jù)代碼,定位到了是Mongodb的報(bào)錯(cuò)。

2.進(jìn)入Mongodb 服務(wù)器的監(jiān)控后臺(tái),這里是在阿里云購(gòu)買的云緩存。

3.知道是Mongodb出問(wèn)題,就好辦了,阿里云里面有個(gè)索引推薦,很好用的,會(huì)給出查詢時(shí)間,執(zhí)行次數(shù),和推薦策略

OK,這里準(zhǔn)備工作就基本做完了。

解決策略:

1.根據(jù)這些給出的執(zhí)行次數(shù),和執(zhí)行時(shí)間慢的,去看了下庫(kù)。從設(shè)計(jì)上,有問(wèn)題,一個(gè)庫(kù)有900W的數(shù)據(jù),然后集合邏輯看了下,這庫(kù)只往里面存數(shù)據(jù),從不清理

2.沒有建立過(guò)索引,包括單一索引和連接索引,這也是會(huì)導(dǎo)致慢的一個(gè)原因。優(yōu)化后是這樣的,

db.getCollection('course_study_history').createIndex({'studentId':1,'contentStudyID':1,'courseWareID':1,'courseStudyId':1})

3.一個(gè)查詢總數(shù)的方法有問(wèn)題,下面是修改后的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")));

最開始的寫法,大概就類型,Mysql 里,查詢某個(gè)list,然后list.size(),得出總數(shù),

修改后的方法:大概就相當(dāng)于 count(id) 得出總數(shù),

這樣的話,修改后的方法,肯定就會(huì)比修改前的快。

方案基本決定下來(lái)了,實(shí)施后開始?jí)毫y(cè)試。

沒修改時(shí)的2000并發(fā):

修改后的2000并發(fā):

可以看到時(shí)間,也明顯的提高了。

并且測(cè)試4000 并發(fā),雖然慢了,不過(guò)沒崩掉。

再查看CPU信息,沒有出現(xiàn)100%的情況了。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • mongodb?數(shù)據(jù)塊的遷移流程分析

    mongodb?數(shù)據(jù)塊的遷移流程分析

    這篇文章主要介紹了mongodb?數(shù)據(jù)塊的遷移流程介紹,包括數(shù)據(jù)塊遷移對(duì)集群性能的影響,建議設(shè)置平衡器的活躍時(shí)間窗口,設(shè)置為業(yè)務(wù)低估時(shí)進(jìn)行,具體操作步驟文中有介紹,需要的朋友可以參考下
    2022-04-04
  • 解決MAC上啟動(dòng)mongod報(bào)錯(cuò)exiting with code 1的問(wèn)題

    解決MAC上啟動(dòng)mongod報(bào)錯(cuò)exiting with code 1的問(wèn)題

    這篇文章主要介紹了解決MAC上啟動(dòng)mongod報(bào)錯(cuò)exiting with code 1的問(wèn)題,本文給大家介紹的非常詳細(xì)對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • mongodb基礎(chǔ)之用戶權(quán)限管理實(shí)例教程

    mongodb基礎(chǔ)之用戶權(quán)限管理實(shí)例教程

    這篇文章主要給大家介紹了關(guān)于mongodb基礎(chǔ)之用戶權(quán)限管理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-06-06
  • MongoDB安裝圖文教程

    MongoDB安裝圖文教程

    這篇文章主要為大家詳細(xì)介紹了MongoDB安裝圖文教程,分為兩大部分為大家介紹下載MongoDB和安裝MongoDB的方法,感興趣的小伙伴們可以參考一下
    2016-07-07
  • MongoDB 常用的數(shù)據(jù)類型和基本操作

    MongoDB 常用的數(shù)據(jù)類型和基本操作

    這篇文章主要介紹了MongoDB 常用的數(shù)據(jù)類型和基本操作,幫助大家更好的理解和學(xué)習(xí)使用MongoDB數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2021-03-03
  • 在MongoDB中實(shí)現(xiàn)時(shí)間范圍查詢的代碼詳解

    在MongoDB中實(shí)現(xiàn)時(shí)間范圍查詢的代碼詳解

    MongoDB作為一個(gè)高性能、開源、無(wú)模式的文檔型數(shù)據(jù)庫(kù),廣泛應(yīng)用于各種需要靈活數(shù)據(jù)模型的應(yīng)用場(chǎng)景中,在處理與時(shí)間相關(guān)的數(shù)據(jù)時(shí),MongoDB提供了強(qiáng)大的查詢能力,本文將詳細(xì)介紹如何在MongoDB中執(zhí)行時(shí)間范圍查詢,需要的朋友可以參考下
    2024-08-08
  • 解決net start MongoDB 報(bào)錯(cuò)之服務(wù)名無(wú)效的問(wèn)題

    解決net start MongoDB 報(bào)錯(cuò)之服務(wù)名無(wú)效的問(wèn)題

    這篇文章主要介紹了解決net start MongoDB 報(bào)錯(cuò)之服務(wù)名無(wú)效的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • MongoDB性能優(yōu)化及監(jiān)控

    MongoDB性能優(yōu)化及監(jiān)控

    MongoDB 是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫(kù)。接下拉通過(guò)本文給大家分享MongoDB性能優(yōu)化及監(jiān)控,本文介紹的非常詳細(xì),非常具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧
    2016-02-02
  • MongoDB 主分片(primary shard)相關(guān)總結(jié)

    MongoDB 主分片(primary shard)相關(guān)總結(jié)

    這篇文章主要介紹了MongoDB 主分片(primary shard)相關(guān)總結(jié)。幫助大家更好的理解和學(xué)習(xí)使用MongoDB,感興趣的朋友可以了解下
    2021-03-03
  • MongoDB為什么比Mysql快原理解析

    MongoDB為什么比Mysql快原理解析

    這篇文章主要為大家介紹了MongoDB為什么比Mysql快原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03

最新評(píng)論