记录一次docker集群中搭建mongodb副本集

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

1.创建三个装有mongo的docker容器,这里使用docker-compose,配置如下

mongo:
    image: mongo
    command: mongod -f /etc/mongo.conf
    volumes:
      - ${DATA_PATH_HOST}/mongo:/data/db
      - ${CONF_PATH}/mongo/mongo_yaml.conf:/etc/mongo.conf
      - ${CONF_PATH}/mongo/access.key:/etc/access.key
    expose:
      - 27017
    ports:
      - 27017:27017
    networks:
      - backend


mongo2:
    image: mongo
    command: mongod -f /etc/mongo.conf
    volumes:
        - ${DATA_PATH_HOST}/mongo2:/data/db
        - ${CONF_PATH}/mongo/mongo_yaml.conf:/etc/mongo.conf
        - ${CONF_PATH}/mongo/access.key:/etc/access.key
    expose:
        - 27017
    ports:
        - 27018:27017
    networks:
        - backend


mongo3:
    image: mongo
    command: mongod -f /etc/mongo.conf
    volumes:
        - ${DATA_PATH_HOST}/mongo3:/data/db
        - ${CONF_PATH}/mongo/mongo_yaml.conf:/etc/mongo.conf
        - ${CONF_PATH}/mongo/access.key:/etc/access.key
    expose:
        - 27017
    ports:
        - 27019:27017
    networks:
        - backend

其中mongo.conf 为yaml格式的mongodb配置文件,内容如下

processManagement:
   fork: false
net:
   bindIp: 127.0.0.1
   port: 27017
storage:
   dbPath: /data/db
systemLog:
   #destination: file
   #path: log/mongo27017.log
   logAppend: true
storage:
   journal:
      enabled: true
replication:
   oplogSizeMB: 500
   replSetName: "r1"
   secondaryIndexPrefetch: "all"

执行docker-compose up -d mongo mongo2 mongo3 创建三个mongo容器 并指定副本集 r1


2. 登入任意一台机器的MongoDB执行:因为是全新的副本集所以可以任意进入一台执行;要是有一台有数据,则需要在有数据上执行;要多台有数据则不能初始化。我个人是mongo中有数据但是mongo2和mong3是空的数据库,所以我登录mongo1进行副本集初始化。

    执行命令 docker-compose exec mongo bash 进入容器

    执行命令  mongo  在容器内部连接mongo

    执行一下命令初始化副本集


> use admin
switched to db admin
> config = { "_id": "r1", "members": [{ "_id": 0, "host": "mongo:27017", "priority": 1 }, { "_id": 1, "host": "mongo2:27017", "priority": 1 }, { "_id": 2, "host": "mongo3:27017", "priority": 1 }] }
{
	"_id" : "r1",
	"members" : [
		{
			"_id" : 0,
			"host" : "mongo:27017",
			"priority" : 1
		},
		{
			"_id" : 1,
			"host" : "mongo2:27017",
			"priority" : 1
		},
		{
			"_id" : 2,
			"host" : "mongo3:27017",
			"priority" : 1
		}
	]
}
> rs.initiate(config)
{
	"ok" : 1,
	"operationTime" : Timestamp(1539830924, 1),
	"$clusterTime" : {
		"clusterTime" : Timestamp(1539830924, 1),
		"signature" : {
			"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
			"keyId" : NumberLong(0)
		}
	}
}


副本集初始化完成,可以使用命令rs.status()查看当前副本集状态,至此mongodb副本集设置完成




3.加入鉴权机制,如果服务端需要开启auth认证,则在启动时通过keyFile三个节点之间的通信授权


使用命令生成keyFile文件

openssl rand -base64 745 > /docker/conf/mongo/mongo-keyfile

ch

如果服务器启动时加入了参数--keyFile = /docker/conf/mongo/mongo-keyfile  则mongo服务端启动时会自动开启auth,故应先创建账号。
创建了账号  root   pass  auth库为admin  (步骤省略)

停止所有节点,重新启动mongo服务,并加上 --keyFile参数

发现报错

mongo3_1     | 2018-10-24T06:13:06.323+0000 I CONTROL  [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify --sslDisabledProtocols 'none'

mongo3_1     | 2018-10-24T06:13:06.331+0000 I ACCESS   [main] permissions on /etc/access.key are too open

mongo2_1     | 2018-10-24T06:13:06.591+0000 I CONTROL  [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify --sslDisabledProtocols 'none'

mongo2_1     | 2018-10-24T06:13:06.605+0000 I ACCESS   [main] permissions on /etc/access.key are too open

mongo_1      | 2018-10-24T06:13:06.609+0000 I CONTROL  [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify --sslDisabledProtocols 'none'

mongo_1      | 2018-10-24T06:13:06.614+0000 I ACCESS   [main] permissions on /etc/access.key are too open

这是因为keyfile权限问题,执行命令将keyfile权限设置为600

chmod 600 /docker/conf/mongo/access.key


再次启动,成功。


进入某一容器执行副本集链接操作,系统提示已成功连接到副本集

32532d16520fedee8d60a05078c6ea2f426d931c

相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
目录
相关文章
|
2月前
|
网络安全 Docker 容器
|
2月前
|
安全 Docker 容器
|
2月前
|
网络安全 Docker 容器
|
2月前
|
网络安全 数据安全/隐私保护 Docker
|
2月前
|
运维 监控 数据安全/隐私保护
管理 Docker Swarm 集群注意事项
【10月更文挑战第7天】
44 3
|
2月前
|
负载均衡 监控 安全
如何管理 Docker Swarm 集群和节点
【10月更文挑战第7天】
65 3
|
24天前
|
Prometheus 监控 Cloud Native
如何使用Prometheus监控Docker Swarm集群的资源使用情况?
还可以根据实际需求进行进一步的配置和优化,如设置告警规则,当资源使用超出阈值时及时发出警报。通过这些步骤,能够有效地使用 Prometheus 对 Docker Swarm 集群的资源进行监控和管理。
41 8
|
24天前
|
Prometheus 监控 Cloud Native
如何监控Docker Swarm集群的性能?
如何监控Docker Swarm集群的性能?
81 8
|
25天前
|
监控 Docker 容器
Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项
本文深入探讨了Docker Swarm集群的扩展与缩容策略,涵盖其意义、方法、步骤及注意事项,旨在帮助用户高效管理集群资源,适应业务变化,确保服务稳定性和资源优化。
46 6
|
1月前
|
NoSQL 容灾 MongoDB
MongoDB主备副本集方案:两台服务器使用非对称部署的方式实现高可用与容灾备份
在资源受限的情况下,为了实现MongoDB的高可用性,本文探讨了两种在两台服务器上部署MongoDB的方案。方案一是通过主备身份轮换,即一台服务器作为主节点,另一台同时部署备节点和仲裁节点;方案二是利用`priority`设置实现自动主备切换。两者相比,方案二自动化程度更高,适合追求快速故障恢复的场景,而方案一则提供了更多的手动控制选项。文章最后对比了这两种方案与标准三节点副本集的优缺点,指出三节点方案在高可用性和数据一致性方面表现更佳。