日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
部署MongoDB分片集群

在Mongodb里面存在另一種集群,就是分片技術(shù),可以滿足MongoDB數(shù)據(jù)量大量增長(zhǎng)的需求。

我們提供的服務(wù)有:成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、微信公眾號(hào)開(kāi)發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、東營(yíng)區(qū)ssl等。為千余家企事業(yè)單位解決了網(wǎng)站和推廣的問(wèn)題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的東營(yíng)區(qū)網(wǎng)站制作公司

當(dāng)MongoDB存儲(chǔ)海量的數(shù)據(jù)時(shí),一臺(tái)機(jī)器可能不足以存儲(chǔ)數(shù)據(jù),也可能不足以提供可接受的讀寫(xiě)吞吐量。這時(shí),我們就可以通過(guò)在多臺(tái)機(jī)器上分割數(shù)據(jù),使得數(shù)據(jù)庫(kù)系統(tǒng)能存儲(chǔ)和處理更多的數(shù)據(jù)。

環(huán)境準(zhǔn)備

Linux環(huán)境

主機(jī) OS 備注
192.168.32.13 CentOS6.3 64位 普通PC
192.168.71.43 CentOS6.2 64位 服務(wù)器,NUMA CPU架構(gòu)

MongoDB版本:mongodb-linux-x86_64-2.4.1,下載地址:www.mongodb.org/downloads.

MongoDB安裝:分別在兩臺(tái)機(jī)器上安裝好mongodb 2.4.1,安裝路徑都為/url/local/mongodb-2.4.1/

cd /usr/local/src/
wget http://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.4.1.tgz
tar -zxvf mongodb-linux-x86_64-2.4.1.tgz
cp -r mongodb-linux-x86_64-2.4.1 /usr/local/mongodb-2.4.1
cd /usr/local/mongodb-2.4.1/bin/
ll

可以看到mongodb安裝成功有如下模塊:

**mongodb**啟動(dòng)和關(guān)閉等在后面集群搭建中有詳細(xì)說(shuō)明,在此不再贅述。

Sharding集群搭建

Mongodb一共有三種集群搭建的方式:Replica Set(副本集)、Sharding(切片)和Master-Slaver(主從)。下面要搭建的是Sharding,Sharding集群也是三種集群中最復(fù)雜的。

配置服務(wù)器啟動(dòng)(192.168.32.13:10000):

1.    ./bin/mongod --fork --dbpath data/config/ --logpath log/config.log –port 10000

路由服務(wù)器啟動(dòng)(192.168.32.13:20000):

1.    ./bin/mongos --port 20000 --configdb 192.168.32.13:10000 --logpath log/mongos.log  --fork

注意1:配置–conigdb的時(shí)候ip地址不能填localhost或127.0.0.1否則添加分片時(shí)會(huì)返回如下錯(cuò)誤信息:

1.    {
2.            "ok" : 0,
3.            "errmsg" : "can't use localhost as a shard since all shards need to communicate. either use all shards and configdbs in localhost or all in actual IPs  host: 192.168.71.43:27017 isLocalHost:0"
4.    }

啟動(dòng)分片1(192.168.32.13:27019):

1.    ./bin/mongod --dbpath data/shard3/ --logpath log/shard3.log  --fork --port 27019

啟動(dòng)分片2(192.168.32.13:27020):

1.    ./bin/mongod --dbpath data/shard3/ --logpath log/shard3.log  --fork --port 27020

啟動(dòng)分片3(192.168.71.43:27017):

1.    numactl --interleave=all ./bin/mongod --dbpath data/shard1/ --logpath log/shard1.log  --fork --port 27017

啟動(dòng)分片4(192.168.71.43:27018):

1.    numactl --interleave=all ./bin/mongod --dbpath data/shard2/ --logpath log/shard2.log  --fork --port 27018

說(shuō)明:關(guān)于這里為什么加numactl –interleave=all,后面有詳細(xì)說(shuō)明。

Note:在生產(chǎn)環(huán)境可以將啟動(dòng)的配置信息寫(xiě)入文件,然后啟動(dòng)的時(shí)候指定配置文件,這樣便于管理:

1.    vi conf/config.conf
2.    bpath=data/config/
3.    logpath=log/config.log
4.    port=10000
5.    fork=true

6.    ./bin/mongod -f conf/config.conf

添加分片1(192.168.32.13:27019):

1.    ./bin/mongo --port 20000
2.    mongos> use admin
3.    switched to db admin
4.    mongos> db.runCommand({addshard:"192.168.32.13:27019",allowLocal:true })

注意2:同樣這里的192.168.32.13不能用localhost或127.0.0.1代替,并且當(dāng)路由進(jìn)程和分片在同一臺(tái)機(jī)器上要指定allowLocal為true,因?yàn)镸ongoDB盡量避免錯(cuò)誤的配置,將集群配置在本地,所以這個(gè)配置指明當(dāng)前僅僅是用于開(kāi)發(fā)。

添加分片3(192.168.71.43:27017):

1.    mongos> db.runCommand({addshard:"192.168.71.43:27017" })

類(lèi)似的添加分片2,4。

分片添加成功返回類(lèi)似下面的信息(當(dāng)前mongodb版本為2.4.1):

1.    { "shardAdded" : "shard0000", "ok" : 1 }

刪除分片:如果要?jiǎng)h除分片的話可以removeshard命令:

1.    mongos> use admin
2.    switched to db admin
3.    mongos> db.runCommand({"removeshard":"192.168.32.13:27020"})
4.    {
5.            "msg" : "draining started successfully",
6.            "state" : "started",
7.            "shard" : "shard0001",
8.            "note" : "you need to drop or movePrimary these databases",
9.            "dbsToMove" : [
10.                    "test3"
11.            ],
12.            "ok" : 1
13.    }

移除分片需要一個(gè)過(guò)程,MongoDB會(huì)把移除的片上的數(shù)據(jù)(塊)挪到其他片上,移動(dòng)中會(huì)顯示進(jìn)度:

1.    mongos> db.runCommand({"removeshard":"192.168.32.13:27020"})
2.    {
3.            "msg" : "draining ongoing",
4.            "state" : "ongoing",
5.            "remaining" : {
6.                    "chunks" : NumberLong(0),
7.                    "dbs" : NumberLong(1)
8.            },
9.            "note" : "you need to drop or movePrimary these databases",
10.            "dbsToMove" : [
11.                    "test3"
12.            ],
13.            "ok" : 1
14.    }

注意:如果刪除的片是數(shù)據(jù)庫(kù)的大本營(yíng)(基片),必須手動(dòng)移動(dòng)或刪除數(shù)據(jù)庫(kù),用moveprimary命令,上面的示例中就提示192.168.32.13:27020是test3庫(kù)的大本營(yíng)(primary),這個(gè)信息可以通過(guò)查看config.databases看到:

1.    mongos> use config
2.    switched to db config
3.    mongos> db.databases.find()
4.    { "_id" : "test3", "partitioned" : false, "primary" : "shard0001" }

這里shard0001就是192.168.32.13:27020,下面通過(guò)moveprimary命令移除test3:

1.    mongos> use admin
2.    switched to db admin
3.    mongos> db.runCommand({"moveprimary":"test3","to":"192.168.32.13:27019"})
4.    { "primary " : "shard0000:192.168.32.13:27019", "ok" : 1 }

這時(shí)再查看config.databases會(huì)發(fā)現(xiàn)test3的大本營(yíng)變成了shard0000(192.168.32.13:27019)

這時(shí)再執(zhí)行removeshard命令則能成功移除分片了:

1.    mongos> db.runCommand({"removeshard":"192.168.32.13:27020"})
2.    {
3.            "msg" : "removeshard completed successfully",
4.            "state" : "completed",
5.            "shard" : "shard0001",
6.            "ok" : 1
7.    }

管理分片

進(jìn)入mongos進(jìn)程config庫(kù)可以看到目前分片的情況:

1.    ./bin/mongo –port 20000
2.    use config
3.    db.shards.find()
1.    mongos> use config
2.    switched to db config
3.    mongos> db.shards.find()
4.    { "_id" : "shard0000", "host" : "192.168.32.13:27019" }
5.    { "_id" : "shard0001", "host" : "192.168.71.43:27017" }
6.    { "_id" : "shard0002", "host" : "192.168.71.43:27018" }

注意3:如果配置過(guò)程中發(fā)生過(guò)上面注意1中出現(xiàn)的情況,即配置configdb的時(shí)候用了localhost或127.0.0.1,則運(yùn)行db.shards.find()可能會(huì)出現(xiàn)如下錯(cuò)誤:

1.    mongos> db.shards.find()
2.    error: {
3.            "$err" : "could not initialize sharding on connection 192.168.32.13:10000 :: caused by :: mongos specified a different config database string : stored : localhost:10000 vs given : 192.168.32.13:10000",
4.            "code" : 15907
5.    }

解決方法是重新啟動(dòng)config進(jìn)程

查看分片后的數(shù)據(jù)庫(kù):

1.    ./bin/mongo –port 20000
2.    use test
3.    db.test.user.insert({“test”: “test”})
4.    ……
5.    use config
6.    db.databases.find()
7.    { "_id" : "admin", "partitioned" : false, "primary" : "config" }
8.    { "_id" : "test", "partitioned" : false, "primary" : "shard0000" }
9.    { "_id" : "test2", "partitioned" : false, "primary" : "shard0000" }
10.    { "_id" : "test3", "partitioned" : false, "primary" : "shard0001" }

“_id”,字符串。表示數(shù)據(jù)庫(kù)名。

“partioned”,布爾型。如果為true則表示開(kāi)啟了分片功能。

“primary”,字符串,這個(gè)值與“_id”對(duì)應(yīng)表示這個(gè)數(shù)據(jù)庫(kù)的“大本營(yíng)“在哪里,不論分片與否,數(shù)據(jù)庫(kù)總是會(huì)有個(gè)“大本營(yíng)”,創(chuàng)建數(shù)據(jù)庫(kù)時(shí)會(huì)隨機(jī)選擇一個(gè)片,也就是說(shuō)大本營(yíng)是開(kāi)始創(chuàng)建數(shù)據(jù)庫(kù)文件的位置。雖然分片的時(shí)候數(shù)據(jù)庫(kù)也會(huì)用到很多別的服務(wù)器,但是從這分片開(kāi)始。

至此整個(gè)mongodb分片集群基本搭建完成,但是想讓分片正常、高效、穩(wěn)定的運(yùn)行還有很多工作要做,下一節(jié)將在此基礎(chǔ)上做一些簡(jiǎn)單的測(cè)試。


當(dāng)前文章:部署MongoDB分片集群
URL分享:http://www.5511xx.com/article/dhdjged.html