用Docker部署一个MongoDB集群详解
发布日期:2016-4-21 10:4:29
用Docker部署一个MongoDB集群详解 简介:MongoDB是一个介于关系数据库和非关系数据库之间的产品,并不像mysql那样的关系型。是非关系数据库当中最像关系数据库的。支持类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。本文介绍了如何使用Docker搭建MongoDB集群。 通过本文向大家介绍如何使用Docker部署一个MongoDB集群,具体如下所示:
首先你需要准备三个运行的Docker服务器,你要准备一个安装了Docker的本地Vagrant Box虚拟机(系统可以使用CoreOS)或使用AWS,当然,也可以使用其它的你喜欢的方式。 一、详细步骤 步骤1:你要拿到3台Docker服务器的IP地址,将下面给出的IP地址配置到所有的服务器上面,而且每一台服务器都要执行如下命令,在执行命令时记得要替换掉IP地址。命令的代码如下所示: root@node *:/# export node1=10.11.32.174 root@node *:/# export node2=10.11.33.37 root@node *:/# export node3=10.11.31.176 虽然在理想情况下你可以不这么做,这些IP能通过DNS自动配置好的。但是这样会更加简单,毕竟这只是一次安装测试。 步骤2:为每个节点创建密钥文件。在其中的一台服务器上面执行下面所示的命令,接着就把密钥文件复制到其余两个服务器的同样的位置。 在本次教程中,我把所有的东西都放在“/home/core”文件夹中。命令的代码如下所示: root@node *:/# mkdir -p /home/core root@node *:/# cd /home/core root@node *:/# openssl rand -base64 741 > mongodb-keyfile root@node *:/# chmod 600 mongodb-keyfile root@node *:/# sudo chown 999 mongodb-keyfile 这个密钥文件的所有者被设置成id为“999”的用户了,由于在MongoDB的Docker容器中,这个用户需要有操作密钥文件的权限。 步骤3:启动即第一台Docker服务器的MongoDB容器。由于它会启动一个没有身份验证机制的容器,所以我们就需要设置一个用户。创建用户的命令如下所示: root@node1:/# docker run --name mongo \ -v /home/core/mongo-files/data:/data/db \ -v /home/core/mongo-files:/opt/keyfile \ --hostname="node1.example.com" \ -p 27017:27017 \ -d mongo:2.6.5 --smallfiles 现在我们创建一个admin用户。我们可以连接到刚刚启动的mongoDB容器,并且进入一个交互式的shell环境.代码如下所示: root@node1:/# docker exec -it mongo /bin/bash 这时候我们就进到MongoDB的Docker容器里面了,然后我们要打开一个mongo shell环境,代码如下所示: root@node1:/# mongo 通过上面所说的命令,我们可以打开mongo shell环境。执行上面所示的命令代码后你会看到如下所示的的输出: MongoDB shell version: 2.6.5 connecting to: test Welcome to the MongoDB shell. For interactive help, type "help". For more comprehensive documentation, see http://docs.mongodb.org/ Questions? Try the support group http://groups.google.com/group/mongodb-user > 切换到admin用户,代码如下所示: > use admin switched to db admin 创建一个新的site admin 用户,代码如下所示: > db.createUser( { user: "siteUserAdmin", pwd: "password", roles: [ { role: "userAdminAnyDatabase", db: "admin" } ] }); 如果创建成功的话你会看到如下的成功信息,代码如下所示: Successfully added user: { "user" : "siteUserAdmin", "roles" : [ { "role" : "userAdminAnyDatabase", "db" : "admin" } ] } 创建一个root用户,代码如下所示: > db.createUser( { user: "siteRootAdmin", pwd: "password", roles: [ { role: "root", db: "admin" } ] }); 你会看到如下的成功信息,代码如下所示: Successfully added user: { "user" : "siteRootAdmin", "roles" : [ { "role" : "root", "db" : "admin" } ] } 我们已经创建好了我们以后要使用的几个用户,现在我们不会退出交互式shell环境(mongo与Docker容器的环境),代码如下: > exit bye root@node1:/# exit 步骤4:停止第一个MongoDB的实例,执行代码如下所示: root@node1:/# docker stop mongo 步骤5:这次使用密钥文件启动第一台MongoDB实例(还是在node1上面操作的),示例执行的代码如下所示。 root@node1:/# docker rm mongo root@node1:/# docker run \ --name mongo \ -v /home/core/mongo-files/data:/data/db \ -v /home/core/mongo-files:/opt/keyfile \ --hostname="node1.example.com" \ --add-host node1.example.com:${node1} \ --add-host node2.example.com:${node2} \ --add-host node3.example.com:${node3} \ -p 27017:27017 -d mongo:2.6.5 \ --smallfiles \ --keyFile /opt/keyfile/mongodb-keyfile \ --replSet "rs0" 这里你需要注意的地方: --keyFile的路径是/opt/keyfile/mongodb-keyfile,这是正确的。这是密钥文件在Docker内部的地址,我们用-v选项将密钥文件映射到容器内部的那个路径上(即:/opt/keyfile/mongodb-keyfile)。 --add-host把这些信息添加到Docker容器的/etc/hosts文件中,所以我们可以使用域名而不是IP地址了。在实际的生产环境中这些信息都是DNS,这些参数都可以忽略。 步骤6:连接到副本集上,安装配置好它。这还是在node1上面进行的。我们要开启另外一个新的交互式shell环境进入mongo容器,同时开启一个mongo shell环境,执行代码如下所示: root@node1:/# docker exec -it mongo /bin/bash root@node1:/# mongo MongoDB shell version: 2.6.5 > 切换到admin用户下,如以下命令: > use admin switched to db admin 由于我们已经设置了一个密码,因此这次我们不得不做身份验证。我们把密码设置为:password。 > db.auth("siteRootAdmin", "password"); 1 现在我们可以开启副本集: > rs.initiate() { "info2" : "no configuration explicitly specified -- making one", "me" : "node1.example.com:27017", "info" : "Config now saved locally. Should come online in about a minute.", "ok" : 1 } > 步骤7:验证已经初始化的副本集的配置,执行代码如下: > rs0:PRIMARY> rs.conf() { "_id" : "rs0", "version" : 1,r "members" : [ { "_id" : 0, "host" : "node1.example.com:27017" } ] } 步骤8:在其余的两个节点启动MongoDB。 在node2上面执行以下所示的命令: root@node2:/# docker run \ --name mongo \ -v /home/core/mongo-files/data:/data/db \ -v /home/core/mongo-files:/opt/keyfile \ --hostname="node2.example.com" \ --add-host node1.example.com:${node1} \ --add-host node2.example.com:${node2} \ --add-host node3.example.com:${node3} \ -p 27017:27017 -d mongo:2.6.5 \ --smallfiles \ --keyFile /opt/keyfile/mongodb-keyfile \ --replSet "rs0" 在node3上面执行以下所示的命令: root@node3:/# docker run \ --name mongo \ -v /home/core/mongo-files/data:/data/db \ -v /home/core/mongo-files:/opt/keyfile \ --hostname="node3.example.com" \ --add-host node1.example.com:${node1} \ --add-host node2.example.com:${node2} \ --add-host node3.example.com:${node3} \ -p 27017:27017 -d mongo:2.6.5 \ --smallfiles \ --keyFile /opt/keyfile/mongodb-keyfile \ --replSet "rs0" 步骤9:将那两个节点加到副本集上。 回到node1节点若你在这里按了几次回车键(enter)的话,你会看到下面所示的提示代码:“rs0:PRIMARY”。这是由于这个节点是副本集“rso”的主节点。代码如下: rs0:PRIMARY> rs.add("node2.example.com") rs0:PRIMARY> rs.add("node3.example.com") 我们可以通过执行以下所示的命令来验证其它两个节点是否正确的加到这个副本集当中: rs0:PRIMARY> rs.status() 可能会花几分钟的时间来将node1上面的数据同步到其余的两个节点上面。你可以通过查看日志来观察每一个MongoDB的Docker容器里面发生了什么。在任意一个服务器上面执行下面的命令就可以了: root@node*:/# docker logs -ft mongo 二、结论 现在你拥有了一个MongoDB集群。你可以自由的在任何时刻添加节点到这个集群上。你甚至可以关闭其中的一个节点,包括主节点,然后观察一个另外一个节点重新变成了主节点。由于这些数据都被写在了你的本机文件系统当中了,所以重启任何一个节应该都不是什么大问题。 原文链接:Deploy a MongoDB Cluster in 9 steps Using Docker 接下来我们会更新一些mysql的信息,敬请关注。 上一条: 你清楚数据库(MySql)连接吗? 下一条: 你好!PostgreSQL
|