时间:2021-07-01 10:21:17 帮助过:3人阅读
编写Mongos的Dockerfile:
FROM robin/mongod:master EXPOSE 27017 ENTRYPOINT ["usr/bin/mongos"]
构建镜像:
sudo docker build -t robin/mongos:master .
第二步 启动mongodb集群所需的Docker容器:
创建副本集1
docker run --name rs1_srv1 -p 21117:27017 -d robin/mongod:master --noprealloc --smallfiles --replSet rs1 docker run --name rs1_srv2 -p 21217:27017 -d robin/mongod:master --noprealloc --smallfiles --replSet rs1 docker run --name rs1_srv3 -p 21317:27017 -d robin/mongod:master --noprealloc --smallfiles --replSet rs1
-p 映射宿主机器和容器内部的端口。-d 表示deamon模式运行。
--smallfile 减小初始化数据文件的大小,并限制数据文件最大为512M (reduces the initial size for data files and limits the maximum size to 512 megabytes).
--noprealloc主要是为了节省硬盘,禁掉预先分配硬盘。生产环境不要用该选项,会导致性能下降,产生磁盘碎片。
创建副本集2
docker run --name rs2_srv1 -p 22117:27017 -d robin/mongod:master --noprealloc --smallfiles --replSet rs2 docker run --name rs2_srv2 -p 22217:27017 -d robin/mongod:master --noprealloc --smallfiles --replSet rs2 docker run --name rs2_srv3 -p 22317:27017 -d robin/mongod:master --noprealloc --smallfiles --replSet rs2
创建配置容器
docker run --name cfg1 -p 20117:27017 -d robin/mongod:master --noprealloc --smallfiles --configsvr --dbpath /data/db --port 27017 docker run --name cfg2 -p 20217:27017 -d robin/mongod:master --noprealloc --smallfiles --configsvr --dbpath /data/db --port 27017 docker run --name cfg3 -p 20317:27017 -d robin/mongod:master --noprealloc --smallfiles --configsvr --dbpath /data/db --port 27017
创建mongo router
找到配置容器对应的ip 和port
使用mac boot2docker +VirtualBox 一定要注意宿主机的ip是VirtualBox 而不是本机的
运行下边的命令得到容器宿主机器ip
boot2docker ip
docker run --name mongos_router -p 27017:27017 -d robin/mongos:master --configdb <宿主ip>:20117,<宿主ip>:20217,<宿主ip>:20317 --port 27017
这里只创建一台路由服务,这样会存在单点故障问题,可以创建三台来解决问题。
第三步配置副本集与分片
配置副本集1
//连接到rs1_svr1 mongo <宿主ip>:21117 //配置副本集 rs.initiate(); rs.add("<宿主ip>:21217"); rs.add("<宿主ip>:21317"); rs.status(); Fix hostname of primary. cfg = rs.conf(); cfg.members[0].host = "<宿主ip>:21117"; rs.reconfig(cfg); rs.status(); //以上命令一个一个执行
配置副本集2
//连接到rs2_svr1 mongo <宿主ip>:22117 //配置副本集 rs.initiate(); rs.add("<宿主ip>:22217"); rs.add("<宿主ip>:22317"); rs.status(); Fix hostname of primary. cfg = rs.conf(); cfg.members[0].host = "<宿主ip>:22117"; rs.reconfig(cfg); rs.status(); //以上命令一个一个执行
配置分片
//连接到路由服务器 mongo <宿主ip>:27017 sh.addShard("rs1/<宿主ip>:27017"); sh.addShard("rs2/<宿主ip>:27017"); sh.status();
然后测试OK
如果用mac VirtualBox搭建docker 可能会遇到mongo分配文件空间不足的问题,调下磁盘大小就OK了
转发标注来源:http://my.oschina.net/robinyao/blog/469431
利用Docker部署mongodb集群--分片与副本集
标签: