MongoDB分片(sharding)

来源:http://www.cnblogs.com/ganchuanpu/archive/2016/12/24/6217342.html
-Advertisement-
Play Games

1.概念 分片(sharding)是指將數據拆分,將其分散存在不同的機器上的過程。有時也用分區(partitioning)來表示這個概念。將數據分散到不同的機器上,不需要功能強大的大型電腦就可以儲存更多的數據,處理更多的負載。 2.分片 mongos就是一個路由伺服器,它會根據管理員設置的“片鍵” ...


1.概念

分片(sharding)是指將數據拆分,將其分散存在不同的機器上的過程。有時也用分區(partitioning)來表示這個概念。將數據分散到不同的機器上,不需要功能強大的大型電腦就可以儲存更多的數據,處理更多的負載。

 

2.分片

mongos就是一個路由伺服器,它會根據管理員設置的“片鍵”將數據分攤到自己管理的mongod集群,數據和片的對應關係以及相應的配置信息保存在“config伺服器”上。 mongod:一個普通的資料庫實例,如果不分片的話,我們會直接連上mongod。

 

3.如果實現分片

①創建三個目錄,分別存放兩個mongod服務的數據文件和config服務的數據文件

 

②開啟config伺服器 。mongos要把mongod之間的配置放到config伺服器裡面,所以首先開啟它,這裡就使用2222埠。

命令為: mongod --dbpath E:\sharding\config_node --port 2222

 

③開啟mongos伺服器 。這裡要註意的是我們開啟的是mongos,埠3333,同時指定下config伺服器。

命令為: mongos --port 3333 --configdb=127.0.0.1:2222

 

④啟動mongod伺服器 。對分片來說,也就是要添加片了,這裡開啟兩個mongod服務,埠分別為:4444,5555。命令為:

mongod --dbpath E:\sharding\mongod_node1 --port 4444
mongod --dbpath E:\sharding\mongod_node2 --port 5555

 

⑤服務配置 。client直接跟mongos打交道,也就說明我們要連接mongos伺服器,然後將4444,5555的mongod交給mongos,添加分片也就是addshard()。

⑥開啟資料庫分片功能,命令很簡單 enablesharding(),這裡就開啟test資料庫。

⑦指定集合中分片的片鍵,這裡就指定為person.name鍵。

⑧通過mongos插入10w記錄,然後通過printShardingStatus命令查看mongodb的數據分片情況。

這裡主要看三點信息:  
① shards:     可以看到已經別分為兩個片了,shard0000和shard0001。  
② databases:: 這裡有個partitioned欄位表示是否分區,這裡可以看到test已經分區。  
③ chunks:     集合被砍成四段:                            
無窮小 —— jack0,
jack0 ——jack234813,
jack234813——jack9999,
jack9999——無窮大。

分區情況為:3:1,從後面的 on shardXXXX也能看得出。

 


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

-Advertisement-
Play Games
更多相關文章
  • 1、打開maven存放文件夾找到 conf ->settings.xml 2、maven下載文件預設存放在c盤,可以配置放在別的磁碟 還是settings.xml文件 找到 <localRepository> 複製出來並修改地址 (1)為預設存放路徑 (2)為改後存放路徑 2、idea中配置mave ...
  • idea版本:2016.3 maven: apache-maven-3.3.9 tomcat:apache-tomcat-8.5.8 1、tomcat.apache.org 下載tomcat http://maven.apache.org/download.cgi 下載maven 下載解壓放在專門j ...
  • 一、簡介 網路爬蟲(又被稱為網頁蜘蛛,網路機器人,在FOAF社區中間,更經常的稱為網頁追逐者),是一種按照一定的規則,自動地抓取萬維網信息的程式或者腳本。另外一些不常使用的名字還有螞蟻、自動索引、模擬程式或者蠕蟲。 二、requests Python標準庫中提供了:urllib、urllib2、ht ...
  • 操作系統:Win10 java版本:1.8.0_102 1、下載安裝java JDK(安裝時把jre放在了同級目錄) 地址為:F:\Program Files\Java 目錄下 2、配置環境變數 此電腦 ->右鍵“屬性” ->高級系統設置 ->環境變數 (一)在系統變數中新建:變數名:JAVA_HO ...
  • 題目大意: 給定一個n個數的序列和m個詢問(n,m<=100000)和k,每個詢問包含k+2個數字:l,r,b[1],b[2]...b[k],要求輸出b[1]~b[k]在[l,r]中是否出現。 思路:把所有連續的k個數字hash一下,然後扔進主席樹,詢問時在主席樹中查詢就可以了。 註意(坑)點:1、 ...
  • 觀察者模式由四個角色組成:抽象組件角色,抽象裝飾者角色,具體組件角色,具體裝飾者角色。 抽象組件角色:給出一個抽象介面,以規範“準備接受附加功能”的對象。 抽象裝飾者角色:持有一個組件(Component)對象的引用,並定義一個與抽象組件介面一致的介面。 具體組件角色:定義一個準備接受附加功能的類。 ...
  • renren-security是一個輕量級許可權管理系統,其核心設計目標是開發迅速、學習簡單、輕量級、易擴展;使用Spring MVC、Shiro、MyBatis、Bootstrap、Vue2.x等框架,包含:管理員管理、角色管理、菜單管理、定時任務、參數管理、代碼生成器等。 ...
  • 1.環境準備 下載mongoDB對Java支持的驅動包 驅動包下載地址:https://github.com/mongodb/mongo-java-driver/downloads 2.查詢集合中所有文檔 3.刪除集合中的文檔 4.向集合中插入文檔 5.更新集合中的文檔 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...