品牌 资讯 搭配 材料 时尚 热点 行业 首饰 玉石 行情

环球热资讯!高可用:MongoDB 容器部署

2023-05-08 09:44:24 来源:不止dotNET

MongoDB 是一款 NoSQL 数据,通常用来存储非结构化数据,我们的产品中也有用到,例如:一些文件存储在 MongoDB 的 GridFS 中。


(资料图片仅供参考)

MongoDB 有三种方式来实现高可用:

副本集:副本集是 MongoDB 官方推荐的高可用解决方案。它通过在多个节点上复制数据来实现数据冗余和故障转移。副本集通常包括一个主节点和多个从节点,如果主节点发生故障,从节点可以自动选举出一个新的主节点,从而实现自动故障转移。分片集群:分片集群是一种横向扩展的解决方案,可以将数据分散到多个节点上,从而提高读写性能和可伸缩性。分片集群通常由多个分片节点、多个配置节点和多个代理节点组成,其中分片节点负责存储数据,配置节点负责管理元数据,代理节点负责将客户端请求路由到正确的分片节点上。复制集群:复制集群是一种基于副本集的解决方案,可以将多个副本集组合在一起,从而实现更高的可用性和可扩展性。复制集群通常由多个副本集节点和多个代理节点组成,其中代理节点负责将客户端请求路由到正确的副本集节点上。

本文中选择 MongoDB 的副本集的方式来进行演示,副本集相对简单,也能达到高可用的目的,架构图如下:

为了方便,在一台服务器上使用多个容器的方式来进行部署,真实场景下只需要把三个容器分别部署到三台服务器上即可,具体步骤如下:

1、准备一台 CentOS 服务器,安装好 Docker 和 docker-compose 。

2、在 /home 目录创建 mongodb 目录,进入 mongodb 目录创建 data 目录,data 目录中分别创建 mongo1、mongo2、mongo3 用来存放三个节点的数据。

3、使用命令chmod -R 777 data给 data 目录设置权限。

4、在 mongodb 目录中创建文件 docker-compose.yml ,用来构建容器,内容如下:

version: "3"services:  mongo1:    image: mongo:5.0    container_name: mongo1    restart: always    ports:     - "27017:27017"    volumes:     - ./data/mongo1:/data/db    command: mongod --replSet rs0 --bind_ip_all --port 27017  mongo2:    image: mongo:5.0    container_name: mongo2    restart: always    ports:     - "27018:27017"    volumes:     - ./data/mongo2:/data/db    command: mongod --replSet rs0 --bind_ip_all --port 27017  mongo3:    image: mongo:5.0    container_name: mongo3    restart: always    ports:     - "27019:27017"    volumes:     - ./data/mongo3:/data/db    command: mongod --replSet rs0 --bind_ip_all --port 27017
ports:27017、27018、27019 分别为三个节点对外的端口volumes:将步骤 2 中创建的目录和容器内的数据目录进行映射--replSet rs0:指定副本集的名称为 rs0--bind_ip_all:可以让 MongoDB 实例能够通过所有网络接口进行连接,包括本地主机、局域网和互联网。这通常用于在多个计算机之间共享 MongoDB 数据库,或在具有可用公共 IP 地址的环境中使用。

5、在 mongodb 目录下执行 docker-compose up -d进行容器的构建,成功后如下图:

6、随便进入一个 MongoDB 容器,下面命令为进入容器名 mongo1 的容器内部。

docker exec -it mongo1 bash

7、进入容器内部后,输入mongo命令进入 MongoDB 的命令行模式,在该模式执行下面的命令进行副本集的初始化:

rs.initiate({_id: "rs0", members: [  {_id: 0, host: "10.211.55.3:27017"},  {_id: 1, host: "10.211.55.3:27017"},  {_id: 2, host: "10.211.55.3:27017"}]})
该命令初始化一个名为 rs0 的副本集,并将三个 MongoDB 容器添加为成员。注意:host 中指定的 IP 为服务器的 IP,当然如果使用的是容器 IP 或者容器名称,副本集和能正常启动和运行,但程序连接的时候就会出错 。

8、继续在 MongoDB 的命令行模式执行rs.status(),这个命令可以查看副本集的状态信息,包括成员、主节点和副本集配置。

Mongo1 被指定为了主(Primary),其余两个容器为副本(Secondary)。

9、在 Navicat 中配置连接副本集,如下图:

10、到这里,MongoDB 在 Docker 中部署副本集就已经完成,接下来可以通过一些场景测试下是否能故障自动转移,我验证的场景如下:

重启虚拟机后检查 MongoDB 服务是否正常。使用命令systemctl restart docker将 docker 重启,检查 MongoDB 服务是否正常。使用命令docker stop mongo1将副本集中的主节点停掉,检查剩下的两个从节点是否能重现选举新的主节点。使用命令docker start mongo1将之前的主节点启动,检查是否能自动切换为从节点。将 mongo2、mongo3 这两个从节点都停掉,检查 MongoDB 服务还是否可用,正常情况下应该是不可用,主节点 mongo1 会降级为从,变为只读,直连 mongo1 可以连接进行数据读取,集群无法连接。上面每一步操作后,除了看状态之外,还需要用程序进行连接验证服务是否正常。

11、使用 .NET Core 程序进行验证,创建一个 .NET 6 的控制台程序,引用 NuGet 包 MongoDB.Driver 。

12、Program 类的代码如下:

using MongoDB.Bson;using MongoDB.Driver;var mongoConnectionString = "mongodb://10.211.55.3:27017,10.211.55.3:27018,10.211.55.3:27019/test?replicaSet=rs0&readPreference=primary";var mongoClient = new MongoClient(mongoConnectionString);var database = mongoClient.GetDatabase("test");var collection = database.GetCollection("test"); // 插入一条文档var document = new BsonDocument { { "name", "oec2003" }, { "age", 30 } };collection.InsertOne(document);var documents = await collection.Find(Builders.Filter.Empty).ToListAsync();foreach (var doc in documents){    Console.WriteLine(doc);}
连接字符串中的 replicaSet = rs0 用来指定副本集的名称。readPreference=primary ,将读取偏好设置为主节点,表示只从主节点读取数据,这也是默认模式,除了 primary 外,还有一些其他的配置选项,说明如下:readPreference=primaryPreferred:查询将首选主节点,但如果主节点不可用,则可以从其他节点读取数据。readPreference=secondary:查询将只从副本集的次要节点读取数据。如果没有次要节点可用,则查询将失败。readPreference=secondaryPreferred:查询将优先从次要节点读取数据,但如果没有次要节点可用,则可以从主节点读取数据。readPreference=nearest:查询将从网络延迟最低的节点读取数据。这个选项不考虑节点的角色(主节点或次要节点),而是选择网络最近的节点。

在高可用部署中,一定要结合实际情况进行权衡后,采取既能解决问题,又驾轻就熟的方案,否则,出现问题,如果不能及时解决,效果还不如单机。

标签:

(责任编辑:new01)

相关文章

环球热资讯!高可用:MongoDB 容器部署

​MongoDB是一款NoSQL数据,通常用来存储非结构化数据,我们的产品中也有用到,例如:一些文件存储在MongoDB

2023-05-08 09:44:24

店主买下打错彩票中了30万 直言当时不开心:网友直呼运气爆棚_每日热文

​运气好了,真是挡也挡不住。5月7日上午9时过,在自贡市大安区广华的一家中国体育彩票销售门店内,店主朱先

2023-05-08 09:09:04

高考分数位次是怎么算河南排名及排名及

​1、高考分数位次是怎么算位次排名是指在一组数据中,将这些数据按照大小顺序排列后,每个数据所在的位置称

2023-05-08 08:28:35

【全球时快讯】逐梦工业强市,盐城“奔跑”开局

​在日前召开的全省2022年度高质量发展总结表彰会议上,盐城荣获设区市高质量发展综合考核第一等次。对盐城来

2023-05-08 07:49:38

辽宁省内高速公路建设首用三维激光摊铺技术 报道

​日前,由中铁十九局三公司承建的京哈高速绥中(冀辽界)至盘锦段改扩建工程第三合同段六股河特大桥首联桥面

2023-05-08 06:58:26

3家股份行“接力”城商行农商行下调存款利率-天天聚看点

​继4月份多家城商行、农商行密集下调存款挂牌利率后,5月初始,已有浙商银行、恒丰银行、渤海银行等3家股份

2023-05-08 05:37:15

医疗器械经营许可证变更(医疗器械经营许可证查询)

​1、进行医疗器械经营许可证查询可以下载百度APP,在百度APP中搜索国家政务服务平台小程序,进入后搜索医疗

2023-05-08 03:16:48

少说两个字被罚46万,“小贝饿了”并不冤 环球焦点

​据新民晚报报道,2022年11月,因为在直播中将“原切静腌牛排”说成“原切牛排”,拥有上千万粉丝的“小贝饿

2023-05-08 01:00:04

明日起持延期回乡证可买高铁香港段车票 世界快讯

​据港媒报道,港铁今日(7日)表示,因应国家出入境管理局早前宣布延长特定回乡证的有效期,经与内地相关部

2023-05-07 22:18:45

环球看热讯:中国式现代化的长三角实践|北斗西虹桥基地:打造全方位产业链

​从精确定位到珠峰测量,作为国家重要基础设施的北斗导航系统,已成为当下社会不可或缺的科技力量。

2023-05-07 21:25:47

我国跨境资金流动均衡 外汇储备规模保持基本稳定

​国家外汇管理局5月7日公布最新外汇储备情况,数据显示,中国外汇储备规模保持基本稳定。

2023-05-07 20:22:04

超新超全!20份近1000页最新MEMS报告来了-微速讯

​来源:犀牛财经、西南证券、前瞻产业研究院等  ,谢谢根据Yole研究预测,全球MEMS器件市场规模将从2020年

2023-05-07 19:22:46

全球新资讯:博士学炒股遭遇“网络股神”——我市警方破获一起“荐股骗局”诈骗案

​周口日报全媒体记者陈永团核心阅读:对于炒股,很多人都抱着一朝富贵的心态,觉得股市中的钱好赚。于是,网

2023-05-07 18:21:18

每日热闻!借呗逾期一年还了信用会恢复吗?对信用卡额度有影响吗?

​网购成为这个飞速运转的社会的一种普遍的购物方式,很多朋友在资金跟不上的时候就会选择使用京东白条,一旦

2023-05-07 17:06:39

湛江男子当街捅杀女子案将开庭:起诉书披露其还预谋电杀另三名前同事

​因拒绝前同事的追求,广东湛江20岁女孩陈某萍在街上惨遭杀害。起诉书披露,2022年12月,嫌疑男子黄某南提前

2023-05-07 16:11:04

外媒:乌军袭击克里米亚半岛,一夜之间发送十余架无人机 环球视点

​当地时间5月7日,克里米亚地区官员称,乌克兰一夜之间向克里米亚半岛发送了十多架无人机,其中三架袭击了塞

2023-05-07 15:43:21

福建龙岩新罗区四名干部暴雨夜落水失联 搜救进行中 环球即时

​7日凌晨1点40分左右,在新罗区铁山街道平林村,四名当地干部在龙川溪的一座桥上查看水情时,桥梁突然垮塌,

2023-05-07 14:53:44

当前最新:科大讯飞大模型超越ChatGPT

​作者:王聪彬人工智能在全球掀起了全新热潮,认知大模型技术正在阶跃和快速进化,科大讯飞在今天发布了星火

2023-05-07 13:44:00

07sd101-8电缆井图集电子版|环球速看

​1、尺寸是够的,就是算起来有点繁琐。2、下图中弦长是L=2399,高度h可以根据现有数据及回165°计算出来答,

2023-05-07 12:15:38

每日速讯:范元甄范苗(范元甄)

​范元甄范苗,范元甄这个很多人还不知道,现在让我们一起来看看吧!1、邓力群。本文到此分享完毕,希望对大家

2023-05-07 11:11:59

天天新资讯:破41℃!海南这两地热到破纪录

​海南省气象台预计,7日白天,定安、屯昌、澄迈、儋州、白沙、昌江和东方7个市县的大部分乡镇将出现37℃以上

2023-05-07 10:43:24

电脑看视频卡顿怎么解决_电脑看视频卡顿 全球热头条

​1、一、软件方面的问题如果电脑安装多个杀毒软件(如360安全卫士、腾讯电脑管家、金山毒霸等),

2023-05-07 09:47:57

一季度新型储能新增投运装机规模2.9GW_全球速讯

​据科创板日报,中关村(000931)储能产业技术联盟CNESADataLink全球储能数据库最新发布的不完全统计显示,

2023-05-07 09:00:00

土耳其哈塔伊省交通事故遇难人数升至12人

​土耳其卫生部当地时间5月6日发表声明称,当日在哈塔伊省发生了严重交通事故。截至目前,遇难人数已上升至12

2023-05-07 07:58:29

红利曼丢失影响非常大_世界热点

​观察者网用户_157950红利曼丢不丢意义不大?恰恰相反,丢失红利曼的影响甚至超过伊久姆。接下来北顿和利西

2023-05-07 06:40:36

全球焦点!知晓|11~26℃,全国大中城市巡回招聘“北京站”来了!北京招聘100名政府专职消防员!北京5月教育考试工作安排来了!

​今日天气今日晴,气温11~26℃风力:东北风转西南风1级空气质量:良l紫外线强度:最强洗车指数:适宜特别关

2023-05-07 05:04:44

都匀市气象台继续发布雷电黄色预警信号【Ⅲ/较重】【2023-05-07】

​都匀市气象台5月7日1时22分继续发布雷电黄色预警信号:预计未来3小时我市毛尖镇、绿茵湖街道、沙包堡街道、

2023-05-07 02:04:40

连续7天!渤海海峡黄海北部执行军事任务,禁止驶入

​据中国海事局网站消息,大连海事局发布航行警告,自5月7日16时至14日16时,渤海海峡黄海北部执行军事任务,

2023-05-06 23:05:28

三元二次方程题目 三元二次方程

​今天来聊聊关于三元二次方程题目,三元二次方程的文章,现在就为大家来简单介绍下三元二次方程题目,三元二

2023-05-06 22:18:27

美研究:新冠疫情高峰期 美国针对儿童的枪击事件激增一倍多

​​据美国新罕布什尔州公共电台5日报道,美国波士顿大学研究人员表示,新冠疫情高峰期,美国针对儿童的枪击

2023-05-06 21:08:14