用Docker搭建MongoDB集群(副本集)并启用认证用户名密码登录

副本集模式(Replica Set),主备模式的升级版。主节点挂了可以自动投票选主。

主节点:可读可写,只有主节点可写;

备节点:可读不可写,可以用来分担主节点读操作压力。主节点挂了,选主之后,备节点升为主节点,才能写;

仲裁节点:只参与投票,没有读写能力;

这里搭建的是1个主节点,1个备节点,1个仲裁节点。

一、安装、配置、启动副本集集群

1. 拉取MongoDB镜像

docker pull mongo:latest

2. 建配置目录,写配置文件

建配置目录

mkdir -p /mongodb_test/mongo_cluster/config
cd /mongodb_test/mongo_cluster/config

编辑配置文件

# mongod.conf

# for documentation of all options, see:
#   http://docs.mongodb.org/manual/reference/configuration-options/

# Where and how to store data.
#storage:
#  dbPath: /data/db
#  engine:
#  wiredTiger:

# where to write logging data.
systemLog:
  destination: file
  logAppend: true
  path: /data/log/mongo.log

# network interfaces
#net:
#  port: 27017
#  bindIp: 127.0.0.1


# how the process runs
#processManagement:
#  timeZoneInfo: /usr/share/zoneinfo

# 安全项先保持注释状态,配好集群后放开。mongo.key后面步骤里会有生成。
# security:
#   keyFile: /etc/mongo/mongo.key
#   authorization: enabled

#operationProfiling:

# 配副本集名
replication:
  replSetName: "rs0"  

#sharding:

## Enterprise-Only Options:

#auditLog:

#snmp:

3. 编写启动脚本

写三个节点的启动脚本。三个节点的配置文件要保持一致,如果也是在一台机器上部3个虚拟节点,后面2个节点记得替换一下节点目录、替换一下端口映射,这里只列举节点1的脚本。

vim run_mongo_cluster_node1.sh

脚本内容

docker run --name mongo_node1 \
        -h mongo_node1 \
        -v /home/xushuzhen/mongodb_test/mongo_cluster/data/node1:/data/db \
        -v /home/xushuzhen/mongodb_test/mongo_cluster/log/node1:/data/log \
        -v /home/xushuzhen/mongodb_test/mongo_cluster/config:/etc/mongo \
        -p 0.0.0.0:30001:27017 \
        --restart=always \
        -d mongo:latest \
        --config /etc/mongo/mongod.conf

脚本解读

--name mongo_node1 # 容器名
-h mongo_node1 # 容器host名
-v /mongodb_test/mongo_cluster/data/node1:/data/db # 数据库存储路径映射
-v /mongodb_test/mongo_cluster/log/node1:/data/log # 日志存储路径映射
-v /mongodb_test/mongo_cluster/config:/etc/mongo # 配置文件路径映射,三个节点的配置文件保持一致
-p 0.0.0.0:30001:27017 # 端口映射
--restart=always # 随Docker服务启动
-d mongo:latest # 后台启动mongo:latest
--config /etc/mongo/mongod.conf # 指定mongo配置文件,这一条要写在-d mongo:latest后面

4. 启动三个节点容器

sh run_mongo_cluster_node1.sh
sh run_mongo_cluster_node2.sh
sh run_mongo_cluster_node3.sh

启动后查看日志可发现,日志提示副本集模式还没有配置集群,状态不可用

5. 配置集群

随便进入一个节点,这里进入节点1。

docker exec -it mongo_node1 bash

使用mongosh,进入mongodb命令行

mongosh

把这个配置粘贴上,回车之后显示OK就可以了。

rs.initiate({
_id: "rs0",
members: [
{ _id: 0, host: "192.168.10.2:30001" },
{ _id: 1, host: "192.168.10.2:30002" },
{ _id: 2, host: "192.168.10.2:30003", arbiterOnly: true }
] })

_id: "rs0"副本集名要和配置文件中的一致。arbiterOnly: true这个是仲裁节点,建议把最后一个节点作为仲裁节点,因为第一个节点作为仲裁会报个错。通常第一个节点是主节点。

这个时候已经可以使用mongo集群了,但是没有认证,不安全。

二、开启认证

实现连接集群使用用户名密码,节点间通信使用key文件

1. 创建root权限用户

docker exec -it mongo_node1 bash进入一个节点,mongosh进入mongodb命令行,执行命令:

切到admin库

use admin

创建用户,用户名admin123,密码1234567,权限root,所属库admin

db.createUser({user:"admin123",pwd:"1234567",roles:[{role:'root',db:'admin'}]})

2. exit退出容器,关闭集群所有节点

docker stop mongo_node1
docker stop mongo_node2
docker stop mongo_node3

3. 生成key文件,所有节点使用相同的key

生成完移动到配置目录/mongodb_test/mongo_cluster/config中,或者直接cd进去再生成

openssl rand -base64 756 > mongo.key

修改mongo.key的所属用户和权限,一定要修改!不然可能会报错bad key可能报错载不了key文件

sudo chown 999 mongo.key
sudo chmod 400 mongo.key

4. 修改mongod.conf配置文件,放开security部分

# 安全项先保持注释状态,配好集群后放开。mongo.key后面步骤里会有生成。
security:
  keyFile: /etc/mongo/mongo.key
  authorization: enabled

5. 启动集群所有节点

docker start mongo_node1
docker start mongo_node2
docker start mongo_node3

到此,认证开启完毕,集群可以使用了

三、连接集群

我这用的是Studio 3T免费的,官网地址:https://studio3t.com/

连接类型选副本集,成员加上主副节点,填入副本集名,读取偏好看需选择:

image.png

选择加密方式,填入用户名密码,填入所属库:

image.png

测试链接,都显示ok就可以了

image.png

链接成功,会自动识别出集群成员

image.png

添加、删除节点方法可参考MongoDB集群添加、删除节点

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容