mongodb 性能篇

来源:http://www.cnblogs.com/hodge01/archive/2016/12/02/6125264.html
-Advertisement-
Play Games

這是mongodb裡面學習的關於性能的知識點,資料庫的管理無非就是維護和優化。維護在於平時的功能維護,其中優化就包括慢查詢和性能提高了。本次文章裡面提到從索引建立到監控,比較全面的闡述了在mongodb的優化中需要的過程。希望對自己日後的工作提供方便查閱,也希望對大家有用。 ...


一、  索引及其優化

  1. 索引的概述
    1. 資料庫的索引好比是一本書前面的目錄,能加快數據查詢的速度。
    2. 適當的地方增加索引,不合理的地方刪除次優索引,能優化性能較差的應用。
  2. 索引的操作
    1. 基礎索引:db.ken.ensureIndex({age:1}) //在列age上創建索引

1           Name為_id_的是系統索引,不能刪除。

  1. 靜默方式創建索引:db.ken.ensureIndex({x:1},{background:true}); //後臺創建
  2. 文檔索引:嵌入式文檔用不上索引
  3. 組合索引:多個條件一起
  4. 唯一索引:聲明唯一性,就是不能插入此條件相同的數據
  5. 強制使用索引:hint({_id:1})
  6. 刪除索引:db.ken.dropIndex()
  7. 重建索引:db.ken.reIndex()
  8. 用explain查看計劃的執行方式

1           Millis欄位可以看到耗時情況,indexBound可以看到是否在用索引,n表示返回的文檔數量,nscaned表示掃描的文檔數量。

2           如果信息不全,可以嘗試用其他版本的客戶端。

  1. 優化器:Profiler
    1. 開啟功能。

1           可通過啟動的時候加參數:-profiler=1

2           執行命令:db.setProfilingLevel(1)

  1. 查詢記錄:db.system.profiler.find()
  2. 性能優化概述
    1. 性能優化原則:一次修改一個參數
    2. 影響性能的參數:操作系統、網路、硬體、應用伺服器、應用程式、資料庫、查詢語句
  3. 常用優化方案
    1. 創建縮索引:寫少讀多的時候
    2. 限定返回條數:limit
    3. 查詢只用到的欄位
    4. 採用Capped Colletion
    5. 採用存儲過程
    6. 強制使用索引
    7. 使用Profiler

二、  性能監控

  1. Mongosniff工具
  2. Mongostat工具
  3. 使用db.serverStatus()
  4. 使用db.stats()
  5. http監控介面

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一範式:確保每列的原子性(欄位不可分). 如果每列(或者每個屬性)都是不可再分的最小數據單元(也稱為最小的原子單元),則滿足第一範式. 例如:顧客表(姓名、編號、地址、……)其中"地址"列還可以細分為國家、省、市、區等。 第二範式:在第一範式的基礎上更進一層,目標是確保表中的每列都依賴於主鍵. 如 ...
  • flume配置: #DBFile DBFile.sources = sources1 DBFile.sinks = sinks1 DBFile.channels = channels1 # DBFile-DB-Source DBFile.sources.sources1.type = spooldi... ...
  • MYSQL保存BOOLEAN值時用1代表TRUE,0代表FALSE,boolean在MySQL里的類型為tinyint(1), MySQL里有四個常量:true,false,TRUE,FALSE,它們分別代表1,0,1,0, ...
  • 未分區的表,只能存儲在一個FileGroup中;對Table進行分區後,每一個分區都存儲在一個FileGroup,或分散式存儲在不同的FileGroup中。對錶進行分區的過程,是將邏輯上完整的一個表,按照特定的欄位拆分成多個分區,分散到(相同或不同的)FileGroup中,每一個部分叫做表的一個分區 ...
  • 1 概述 在集成項目中需要應對不同環境下的安裝配置,主流操作系統大致可以分為三種:Linux、Windows以及UNIX。其中Linux備受青睞的主要原因有兩個: 首先,Linux作為自由軟體有兩個特點:一是它免費提供源碼,二是愛好者可以按照自己的需要自由修改、複製和發佈程式的源碼,並公佈在Inte ...
  • 任務目標: 編譯安裝LAMP 要求(1) 安裝一個模塊化的PHP 要求(2) 安裝一個FPM的PHP 註意PHP需要最後一個安裝,因為需要前兩者的支持. 所以這裡的安裝次序為 1.httpd 2.MariaDB 3.PHP 一、安裝包組 # yum groupinstall "Development... ...
  • 本篇博文主要講解Oracle資料庫SQL語句完整的執行順序,文中也順便稍微提一下Oracle資料庫相關的知識。 ...
  • LifeCycleState: IDLE, START, STOP, ERROR [Source]: org.apache.flume.Source 繼承LifeCycleAware{stop() + start() + getLifeCycleState()} + NamedComponent{g ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...