docker 虚拟机搭建mongodb一主一从一复制_如何使用Docker部署MongoDB副本集

我写了一篇有关如何使用DevOps时尚风格部署mongodb集群的新文章,在本文中,我正在使用Terraform,Ansible,Packer和更酷的技术,我强烈建议您阅读它。

以DevOps时尚风格(将基础架构作为代码)部署MongoDB副本集。


本文将逐步介绍如何使用docker设置带有身份验证的MongoDB副本集。

我们将在本文中使用的是:

  • MongoDB 3.4.1
  • 适用于Mac 1.12.6的Docker

副本集的体系结构

97496718e22a380580cb7ede25d09651.png

带有docker的副本集的架构

4ee16221e5fc848ff6e30692e51df8f4.png

在上图中,我们看到了使用docker复制集的结果。

#先决条件

  • docker基础知识
  • 安装了dockerdocker-machine
  • mongoDB的基础知识
  • bash脚本编写的基础知识

如果您使用的是Mac或Windows,请考虑使用虚拟机。我将在MacOS Sierra上使用VirtualBox运行我们的mongoDB实例。

#步骤1 —创建我们的3个docker-machines

要创建docker机器,我们需要在终端中发出下一个命令:

此命令将使用virtualbox作为我们的虚拟化提供程序创建一个名为manager1的计算机。

现在让我们创建两个左 docker-machine

$ docker-machine create -d virtualbox worker1$ docker-machine create -d virtualbox worker2

要验证是否创建了我们的机器,让我们运行以下命令:

$ docker-machine ls// the result will beNAME ACTIVE DRIVER STATE URL manager1 - virtualbox Running tcp://192.168.99.100:2376 worker1 - virtualbox Running tcp://192.168.99.101:2376worker2 - virtualbox Running tcp://192.168.99.102:2376

#步骤2 — MongoDB主节点的配置

现在我们有了三台机器,让我们将其放置在第一台机器上以启动mongodb配置,让我们运行下一个命令:

$ eval `docker-machine env manager1`

创建我们的MongoDB容器之前,还有一个已经存在了很长讨论了非常重要的课题数据库持久ocker containers,并为实现这一挑战,我们所要做的是创建一个docker volume

$ docker volume create --name mongo_storage

现在,让我们附加创建的卷以启动我们的第一个mongo容器并设置配置。

$ docker run --name mongoNode1 -v mongo_storage:/data -d mongo --smallfiles

接下来,我们需要创建密钥文件。

密钥文件的内容用作副本集成员的共享密码。对于副本集的所有成员,密钥文件的内容必须相同。

$ openssl rand -base64 741 > mongo-keyfile$ chmod 600 mongo-keyfile

接下来,我们创建一个文件夹,用于存放mongo_storage卷中的数据,密钥文件和配置:

$ docker exec mongoNode1 bash -c 'mkdir /data/keyfile /data/admin'

下一步是创建一些管理员用户,让我们创建一个看起来像这样的admin.jscopy.js文件:

// admin.jsadmin = db.getSiblingDB("admin")// creation of the admin useradmin.createUser( { user: "cristian
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值