使用 Docker 構(gòu)建 MongoDB 分片及副本集

? ? ? ? 負載均衡及高可用一直是我們線上服務(wù)架構(gòu)所關(guān)注的重點,本文內(nèi)容,將介紹如何在 Docker 環(huán)境下實現(xiàn) MongoDB 的副本集及分片。

? ? ? ? 在 MongoDB 中,副本集是一組實現(xiàn)了復(fù)制功能的服務(wù)器,其中一個是主服務(wù)器(Primary),用于處理客戶端請求;其余為備份服務(wù)器(Secondary),用于保存主服務(wù)器的副本。如果主服務(wù)器出現(xiàn)故障,備份服務(wù)器將推舉出其中一個成員為主服務(wù)器,繼續(xù)響應(yīng)請求。分片(Sharding)是將數(shù)據(jù)拆分并分散存放在不同機器上,這樣不需要功能強大的大型計算機就可以存儲更多的數(shù)據(jù),處理更大的負載。MongoDB 的分片機制允許你創(chuàng)建一個包含許多臺機器的集群,將數(shù)據(jù)子集分散在集群中,每個分片維護著一個數(shù)據(jù)集合的子集。與單機服務(wù)器和副本集相比,集群架構(gòu)可以使應(yīng)用程序具有更大的數(shù)據(jù)處理能力。

? ? ? ? 副本集是讓多臺服務(wù)器都擁有同樣的數(shù)據(jù)副本,每一臺服務(wù)器都是其他服務(wù)器的鏡像,而每一個分片都擁有和其他分片不同的數(shù)據(jù)子集。

? ? ? ? 分片的目標之一是創(chuàng)建一個擁有5臺、500臺甚至更多機器的集群,整個集群對應(yīng)用程序來說就像是一臺單機服務(wù)器。為了對應(yīng)用程序隱藏數(shù)據(jù)庫架構(gòu)的細節(jié),在分片之前要先執(zhí)行 mongos 進行一次路由過程。這個路由服務(wù)器維護著一個“內(nèi)容列表”,指明了每個分片包含哪些數(shù)據(jù)內(nèi)容。應(yīng)用程序只需要連接到路由服務(wù)器,就可以像使用單機服務(wù)器一樣進行正常的請求了。

? ? ? ? 那么是不是在業(yè)務(wù)剛起步時就進行分片呢?不然。分片不止會增加部署的操作復(fù)雜度,還要求做出設(shè)計決策,而該決策以后很難再更改,所以不必太早分片,但也不宜在系統(tǒng)運行太久之后分片,因為在一個過載的系統(tǒng)上不停服進行分片是非常困難的。可以參考以下四點來決定何時分片:

????????????需要增加可用RAM

????????????增加可用磁盤空間

????????????減輕單臺服務(wù)器的負載

????????????處理單個 mongod 無法承受的吞吐量

? ? ? ? MongoDB 集群包含三個組件:配置服務(wù)器、mongos 服務(wù)器、mongod 服務(wù)器。配置服務(wù)器相當于集群的大腦,保存著集群和分片的元數(shù)據(jù):集群中有哪些分片、分片的是哪些集合以及數(shù)據(jù)塊的分布等。mongos 需要從配置服務(wù)器獲取信息,因此配置服務(wù)器應(yīng)先于任何 mongos 進程啟動。配置服務(wù)器是獨立的 mongod 進程,所以可以像啟動 mongod 一樣啟動配置服務(wù)器,但在 MongoDB3.4 及以后的版本,配置服務(wù)器必須部署為副本集的形式。

準備環(huán)境

一:初始化宿主機系統(tǒng)

?1.安裝程序包

? ? ?yum -y install docker vim net-tools psmisc sysstat telnet wget lsof lrzsz

?????systemctl enable docker

?????setenforce 0

?????vim /etc/sysconfig/selinux ? ?修改Selinux為關(guān)閉狀態(tài)

?????vim /etc/security/limits.conf ? ?修改文件句柄數(shù)

?2.禁止內(nèi)存過度分配

echo 1 > /proc/sys/vm/overcommit_memory

vim /boot/grub2/grub.cfg

? ? numa=off

3.禁用zone_reclaim_mode

? ? cat /proc/sys/vm/zone_reclaim_mode

? ? ? ? 0

4.塊設(shè)備預(yù)讀大小

? ? blockdev --report

? ? blockdev --setra 16 /dev/sdb1

5.禁用大內(nèi)存頁面

? ? if test -f /sys/kernel/mm/transparent_hugepage/enabled; then

? ? echo never > /sys/kernel/mm/transparent_hugepage/enabled

? ? fi

? ? if test -f /sys/kernel/mm/transparent_hugepage/defrag; then

? ? echo never > /sys/kernel/mm/transparent_hugepage/defrag

? ? fi

6.修改文件描述符限制

? ? nofile 64000

? ? nproc? 64000

7.時鐘同步

? ? */2 * * * * ntpdate 1.sg.pool.ntp.org

8.禁用atime,默認relatime

? ? ?vim /etc/fstab

? ? ?UUID=ef6ba050-6cdc-416a-9380-c14304d0d206 /? ? ? ? ? ? ? ? ? ? ? ?xfs? ? ?defaults,noatime? ? ? ? 0 0

? ? noatime,nodiratime?

9.創(chuàng)建所需目錄

mkdir -p /data/db/rs{1..3}

mkdir -p /data/db/conf{1..3}

mkdir -p /data/logs/rs{1..3}

chown -R mongo.mongo /data

二:構(gòu)建鏡像

1.Download Base Image centos7.3

?????docker pull docker.io/centos

2.start centos

?????docker run -d -it --name centos7 docker.io/centos /bin/bash

? ? ?docker run exec -it centos7? bash

? ? ?useradd? mongo

? ? ?usermod mongo -u 1021

? ? ?groupmod -g 1021 mongo

? ? ?mkdir -p /data/db

? ? ?mkdir -p /data/logs

? ? ?chown -R mongo.mongo /data

? ? ?ln -s? /usr/lib64/libsasl2.so.3 /usr/lib64/libsasl2.so.2

? ? ?ln -s /home/mongo/mongodb/bin/* /usr/bin/

?????su - mongo

?????mongo --hlep

? ? ?yum install -y crontabs

? ? ?su - root

? ? ?/usr/sbin/crond

3.docker commit centos 7 centos7

4.docker build -t mongod3.2.11 .

cat Dockerfile

####mongod####

FROM centos7

MAINTAINER Weiwendi

USER mongo

ENTRYPOINT ["/usr/bin/mongod"]

5.docker build -t mongos3.2.11 .?

cat Dockerfile

####mongos####

FROM centos7

MAINTAINER Weiwendi

USER mongo

ENTRYPOINT ["/usr/bin/mongos"]


分發(fā)配置文件

ConfigDB

-------------------------------------------------------------------

port? ? ? ? ? ? =? ?37019

pidfilepath? ? ?=? ?/data/mongodb/configdb/data/mongod.pid

fork? ? ? ? ? ? =? ?true

configsvr? ? ? ?=? ?true

dbpath? ? ? ? ? =? ?/data/mongodb/configdb/data

logpath? ? ? ? ?=? ?/data/mongodb/configdb/logs/mongod.log

logappend? ? ? ?=? ?true

logRotate? ? ? ?=? ?rename

journal? ? ? ? ?=? ?true

directoryperdb? =? ?true

nohttpinterface =? ?true

quiet? ? ? ? ? ?=? ?true

auth? ? ? ? ? ? =? ?true

keyFile? ? ? ? ?=? ?/data/mongodb/key/mongodb-keyfile

profile? ? ? ? ?=? ?1

slowms? ? ? ? ? =? ?2000

storageEngine? ?=? ?wiredTiger

wiredTigerDirectoryForIndexes = true

wiredTigerCacheSizeGB = 100

replSet? ? ? ? ?=? ?cfgdb



mongos

-------------------------------------------------------------------

port? ? ? ? ? ? =? ?47017

pidfilepath? ? ?=? ?/data/mongodb/mongos/data/mongos.pid

fork? ? ? ? ? ? =? ?true

configdb? ? ? ? =? ?cfgdb/192.168.17.128:37019,192.168.17.129:37019,192.168.17.131:37019

logpath? ? ? ? ?=? ?/data/mongodb/mongos/logs/mongos.log

logappend? ? ? ?=? ?true

logRotate? ? ? ?=? ?rename

quiet? ? ? ? ? ?=? ?true

keyFile? ? ? ? =? ?/data/mongodb/mongodb-keyfile



mongod

-----------------------------------------------------------------

port? ? ? ? ? ? =? ?27017

pidfilepath? ? ?=? ?/data/logs/mongod.pid

fork? ? ? ? ? ? =? ?true

dbpath? ? ? ? ? =? ?/data/db

logpath? ? ? ? ?=? ?/data/logs/rs1.log

logappend? ? ? ?=? ?true

logRotate? ? ? ?=? ?rename

journal? ? ? ? ?=? ?true

directoryperdb? =? ?true

nohttpinterface =? ?true

quiet? ? ? ? ? ?=? ?true

auth? ? ? ? ? ?=? ?true

keyFile? ? ? ? =? ?/data/mongodb/key/mongodb-keyfile

profile? ? ? ? ?=? ?1

slowms? ? ? ? ? =? ?2000

storageEngine? ?=? ?wiredTiger

wiredTigerDirectoryForIndexes = true

wiredTigerCollectionBlockCompressor = snappy

wiredTigerJournalCompressor = snappy

wiredTigerCacheSizeGB = 60

replSet? ? ? ?=? ?rs1

oplogSize? ? ?=? ?102400


在三臺主機上啟動Docker容器

創(chuàng)建副本集

172.31.90.39? ?(副本集1)

docker run --name rs1_srv1 -p 21117:27017 --restart=always -v /data/db/rs1:/data/db -v /data/logs/rs1:/data/logs -v /data/conf/rs1:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

docker run --name rs1_srv2 -p 21217:27017 --restart=always -v /data/db/rs2:/data/db -v /data/logs/rs2:/data/logs -v /data/conf/rs2:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

docker run --name rs1_srv3 -p 21317:27017 --restart=always -v /data/db/rs3:/data/db -v /data/logs/rs3:/data/logs -v /data/conf/rs3:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

172.31.90.64? (副本集2)

docker run --name rs2_srv1 -p 21117:27017 --restart=always -v /data/db/rs1:/data/db -v /data/logs/rs1:/data/logs -v /data/conf/rs1:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

docker run --name rs2_srv2 -p 21217:27017 --restart=always -v /data/db/rs2:/data/db -v /data/logs/rs2:/data/logs -v /data/conf/rs2:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

docker run --name rs2_srv3 -p 21317:27017 --restart=always -v /data/db/rs3:/data/db -v /data/logs/rs3:/data/logs -v /data/conf/rs3:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

172.31.90.161? (副本集3)

docker run --name rs3_srv1 -p 21117:27017 --restart=always -v /data/db/rs1:/data/db -v /data/logs/rs1:/data/logs -v /data/conf/rs1:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

docker run --name rs3_srv2 -p 21217:27017 --restart=always -v /data/db/rs2:/data/db -v /data/logs/rs2:/data/logs -v /data/conf/rs2:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

docker run --name rs3_srv3 -p 21317:27017 --restart=always -v /data/db/rs3:/data/db -v /data/logs/rs3:/data/logs -v /data/conf/rs3:/data/conf -v /data/backup:/data/bak -d? registry.newborn-town.com:5000/wtmongodb3.2.11 -f /data/conf/mongodb.conf

配置服務(wù)器

172.31.90.39

? ? docker run --name cfg1 -p 37017:27017 --restart=always -v /data/db/conf1:/data/db -d registry.newborn-town.com:5000/mongod-3.2.10? --storageEngine wiredTiger --smallfiles --configsvr --dbpath /data/db --port 27017

172.31.90.64

? ? docker run --name cfg2 -p 37017:27017 --restart=always -v /data/db/conf2:/data/db -d registry.newborn-town.com:5000/mongod-3.2.10 --storageEngine wiredTiger --smallfiles --configsvr --dbpath /data/db --port 27017

172.31.90.161

? ? docker run --name cfg3 -p 37017:27017 --restart=always -v /data/db/conf3:/data/db -d registry.newborn-town.com:5000/mongod-3.2.10? --storageEngine wiredTiger --smallfiles --configsvr --dbpath /data/db --port 27017

mongos進程

172.31.90.39

? ? docker run --name mongos1 -p 27017:27018 --restart=always -v /data/logs/rs1:/data/logs -d registry.newborn-town.com:5000/mongos-3.2.10? --logpath /data/logs/mongos.log --logappend --configdb 172.31.90.39:37017,172.31.90.64:37017,172.31.90.161:37017? --port 27018

172.31.90.64

? ? docker run --name mongos2 -p 27017:27018 --restart=always -v /data/logs/rs2:/data/logs -d registry.newborn-town.com:5000/mongos-3.2.10? --logpath /data/logs/mongos.log --logappend --configdb 172.31.90.39:37017,172.31.90.64:37017,172.31.90.161:37017? --port 27018

172.31.90.161

? ? docker run --name mongos3 -p 27017:27018 --restart=always -v /data/logs/rs3:/data/logs -d registry.newborn-town.com:5000/mongos-3.2.10? --logpath /data/logs/mongos.log --logappend --configdb 172.31.90.39:37017,172.31.90.64:37017,172.31.90.161:37017? --port 27018

以上啟動Docker容器步驟,可以通過docker compose來管理。

設(shè)置副本集(在mongodb上執(zhí)行)

172.31.90.39

mongo --port 21117

use admin

config_rs = {

? ?"_id":"rs1",

? ?"members": [

? ? ? ?{"_id":0,"host":"172.31.90.39:21117"},

? ? ? ?{"_id":1,"host":"172.31.90.64:21117"},

? ? ? ?{"_id":2,"host":"172.31.90.161:21117"}

? ?]

}

rs.initiate(config_rs)

172.31.90.64

mongo --port 21217

use admin

config_rs = {

? ?"_id":"rs2",

? ?"members": [

? ? ? ?{"_id":0,"host":"172.31.90.39:21217"},

? ? ? ?{"_id":1,"host":"172.31.90.64:21217"},

? ? ? ?{"_id":2,"host":"172.31.90.161:21217"}

? ?]

}

rs.initiate(config_rs)

172.31.90.161

mongo --port 21317

use admin

config_rs = {

? ?"_id":"rs3",

? ?"members": [

? ? ? ?{"_id":0,"host":"172.31.90.39:21317"},

? ? ? ?{"_id":1,"host":"172.31.90.64:21317"},

? ? ? ?{"_id":2,"host":"172.31.90.161:21317"}

? ?]

}

rs.initiate(config_rs)

設(shè)置分片(mongos上執(zhí)行)

use admin

sh.addShard("rs1/172.31.90.39:21117,172.31.90.64:21117,172.31.90.161:21117")

sh.addShard("rs2/172.31.90.39:21217,172.31.90.64:21217,172.31.90.161:21217")

sh.addShard("rs3/172.31.90.39:21317,172.31.90.64:21317,172.31.90.161:21317")

sh.enableSharding("kittylive")

use kittylive

db.user.createIndex({user_id:"hashed"})

db.bill.createIndex({bill_id:"hashed"})

db.giftRecord.createIndex({gift_id:"hashed"})

sh.shardCollection("kittylive.user",{"user_id":"hashed"})

sh.shardCollection("kittylive.bill",{"bill_id":"hashed"})

sh.shardCollection("kittylive.giftRecord",{"gift_id":"hashed"})

設(shè)置塊遷移窗口期

? ? ?use config

?????db.settings.update({ _id : "balancer" }, { $set : { activeWindow : { start : "22:00", stop : "02:00" } } }, true )

?????sh.getBalancerWindow()

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,663評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,125評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 175,506評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,614評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,402評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,934評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,021評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,168評論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,690評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,596評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,784評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,288評論 5 357
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,027評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,404評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,662評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,398評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,743評論 2 370

推薦閱讀更多精彩內(nèi)容