中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MongoDB 3.4中怎么配置sharding分片

發布時間:2021-07-16 16:05:14 來源:億速云 閱讀:140 作者:Leah 欄目:關系型數據庫

這篇文章給大家介紹MongoDB 3.4中怎么配置sharding分片,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

1. 創建配置服務副本集
創建數據目錄,config目錄供配置服務使用,shard目錄供分片數據節點使用
[root@MySQL01 ~]# su - mongo
[mongo@MySQL01 ~]$ cd /data/db
[mongo@MySQL01 db]$ mkdir config01
[mongo@MySQL01 db]$ mkdir config02
[mongo@MySQL01 db]$ mkdir config03
[mongo@MySQL01 db]$ mkdir shard01
[mongo@MySQL01 db]$ mkdir shard02
[mongo@MySQL01 db]$ mkdir shard03

啟動配置服務副本集的每個節點
[mongo@MySQL01 ~]$ mongod --configsvr --replSet fire --dbpath /data/db/config01 --port 10001


[mongo@MySQL01 ~]$ mongod --configsvr --replSet fire --dbpath /data/db/config02 --port 10002


[mongo@MySQL01 ~]$ mongod --configsvr --replSet fire --dbpath /data/db/config03 --port 10003

連接到配置服務器,執行初始化操作
[mongo@MySQL01 ~]$ mongo localhost:10001
MongoDB shell version v3.4.10
connecting to: localhost:10001
MongoDB server version: 3.4.10

> rs.initiate(
...   {
...     _id: "fire",
...     configsvr: true,
...     members: [
...       { _id : 0, host : "MySQL01:10001" },
...       { _id : 1, host : "MySQL01:10002" },
...       { _id : 2, host : "MySQL01:10003" }
...     ]
...   }
... )
{ "ok" : 1 }
fire:SECONDARY> exit
bye

2. 創建分片副本集
啟動副本集的每個節點
[mongo@MySQL01 ~]$ mongod --shardsvr --replSet flame --port 20001 --dbpath /data/db/shard01


[mongo@MySQL01 ~]$ mongod --shardsvr --replSet flame --port 20002 --dbpath /data/db/shard02


[mongo@MySQL01 ~]$ mongod --shardsvr --replSet flame --port 20003 --dbpath /data/db/shard03

連接到分片副本集的一個節點,執行副本集初始化操作
[mongo@MySQL01 ~]$ mongo localhost:20001
MongoDB shell version v3.4.10
connecting to: localhost:20001
MongoDB server version: 3.4.10
> rs.initiate(
...   {
...     _id : "flame",
...     members: [
...       { _id : 0, host : "MySQL01:20001" },
...       { _id : 1, host : "MySQL01:20002" },
...       { _id : 2, host : "MySQL01:20003" }
...     ]
...   }
... )
{ "ok" : 1 }
flame:OTHER> exit
bye

3. 通過 mongos 連接到分片集群
[mongo@MySQL01 ~]$ mongos --configdb fire/MySQL01:10001,MySQL01:10002,MySQL01:10003 --port 30000

4. 增加分片到集群
連接到 mongos,增加上面創建的副本集到集群中
[mongo@MySQL01 ~]$ mongo localhost:30000
MongoDB shell version v3.4.10
connecting to: localhost:30000
MongoDB server version: 3.4.10

mongos> sh.addShard( "flame/MySQL01:40001")
{ "shardAdded" : "flame", "ok" : 1 }

開啟指定數據庫的分片

為sale數據庫開啟分片功能
mongos> sh.enableSharding("sale")
{ "ok" : 1 }


在sale數據庫里面創建一個集合
mongos> use sale
switched to db sale
mongos> 
mongos> show collections
mongos> db.dept.insert({"id":10})
WriteResult({ "nInserted" : 1 })
mongos> db.dept.insert({"id":20})
WriteResult({ "nInserted" : 1 })
mongos> db.dept.insert({"id":30})
WriteResult({ "nInserted" : 1 })

為創建好的集合執行范圍分片
mongos> sh.shardCollection("sale.dept", { id : 1 } )
{
"proposedKey" : {
"id" : 1
},
"curIndexes" : [
{
"v" : 2,
"key" : {
"_id" : 1
},
"name" : "_id_",
"ns" : "sale.dept"
}
],
"ok" : 0,
"errmsg" : "please create an index that starts with the shard key before sharding."
}

發生報錯,需要對集合的分片字段創建索引
mongos> db.dept.ensureIndex({"id" : 1})
{
"raw" : {
"flame/MySQL01:20001,MySQL01:20002,MySQL01:20003" : {
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1,
"$gleStats" : {
"lastOpTime" : {
"ts" : Timestamp(1512224813, 1),
"t" : NumberLong(1)
},
"electionId" : ObjectId("7fffffff0000000000000001")
}
}
},
"ok" : 1
}

對集合執行分片
mongos> sh.shardCollection("sale.dept", { id : 1 } )
{ "collectionsharded" : "sale.dept", "ok" : 1 }

關于MongoDB 3.4中怎么配置sharding分片就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

定远县| 蛟河市| 徐州市| 蒙城县| 赞皇县| 塘沽区| 阿克陶县| 碌曲县| 井冈山市| 政和县| 长乐市| 樟树市| 沾化县| 农安县| 锦屏县| 顺昌县| 称多县| 胶南市| 江源县| 酉阳| 利辛县| 中宁县| 嘉禾县| 辰溪县| 宁南县| 莱芜市| 乌什县| 彰武县| 通许县| 阿图什市| 西林县| 介休市| 惠安县| 大足县| 吴旗县| 鄂伦春自治旗| 固始县| 海门市| 右玉县| 红桥区| 绩溪县|