IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 【MongoDB】基于Docker的MongoDB replica set(副本集)升级 -> 正文阅读

[大数据]【MongoDB】基于Docker的MongoDB replica set(副本集)升级

之前文章【MongoDB】基于Docker的MongoDB replica set(副本集)搭建介绍了如何基于Docker搭建MongoDB副本集,当时的MongoDB版本号为4.4.5
在这里插入图片描述
最近MongoDB最新版本号已经来到了5.0.8
在这里插入图片描述
考虑对MongoDB进行一次升级

但问题出现了,树莓派无法适配最新的大版本5,详见【MongoDB】MongoDB 5.0官方版本不再支持现有树莓派
故只能先尝试升级至版本4的最新版4.4.13


为了减少对现有数据库访问造成影响,需要对三台主机依次进行如下操作,而不能同时下线多台服务

删除旧容器及镜像

由于之前创建容器的时候是使用下面的代码,指定了volumes,故不用担心容器删除后数据丢失

# 10.8.15.51
>>> docker run --name mongo0 -d -p 27017:27017 --restart always -v mongo0:/data/db  mongo:latest --replSet "rs0" --bind_ip_all
# 10.8.15.52
>>> docker run --name mongo1 -d -p 27017:27017 --restart always -v mongo1:/data/db  mongo:latest --replSet "rs0" --bind_ip_all
# 10.8.15.54
>>> docker run --name mongo2 -d -p 27017:27017 --restart always -v mongo2:/data/db  mongo:latest --replSet "rs0" --bind_ip_all

通过如下代码下线服务

# 停
>>> docker stop mongo0
# 删容器
>>> docker rm mongo0
# 删镜像
>>> docker rmi mongo:latest

启动新服务

我们使用docker-compose方式替换掉之前的docker run

version: "3.9"
services:
  mongo0:
    container_name: mongo0
    image: mongo
    expose:
      - 27017
    ports:
      - 27017:27017
    volumes:
      - mongo0:/data/db
    restart: always
    entrypoint:
      [
        "/usr/bin/mongod",
        "--bind_ip_all",
        "--replSet",
        "rs0",
        "--journal",
        "--enableMajorityReadConcern",
        "false"
      ]
    networks:
      - mongo_rs
volumes:
  mongo0:
networks:
  mongo_rs:
    name: mongo_rs

通过如下命令上线服务

>>> docker-compose up -d

验证

依次对三台服务器进行上面的操作后,可以发现

  1. 仅停掉1个节点不影响数据库访问,访问正常
  2. 停掉2个节点后数据库无法访问
  3. 在对2个节点升级后,刷新后发现数据库版本已经变更为4.4.13,即使另1个节点仍为4.4.5
  4. 数据没有丢失

在这里插入图片描述
之后会在x86服务器上进行4.4.5到5.0.8版本的升级,成功后文章会再进行更新


2022-05-12更新

MongoDB自5.0版本开始版本迭代有所变化,在5.0之前,奇数版本号为开发版本,偶数版本号为稳定版本
在这里插入图片描述
而5.0之后版本发布变为

  • Major Releases
  • Rapid Releases

其中Major Releases 一年为周期进行迭代,提供Atlas和本地部署,而Rapid Releases迭代周期更快,且仅提供Atlas。比如目前的Major Releases为5.0,而5.1、5.2、5.3则为Rapid Releases,所以今年将要发布的6.0为5.0之后的Major Releases(看来刷版本号上头了)

继昨天升级成功4.4.13后,今天打算趁热打铁直接升级到5.0.8
方法还用上文中的docker-compose.yml

version: "3.9"
services:
  mongo0:
    container_name: mongo0
    image: mongo:5.0.8
    expose:
      - 27017
    ports:
      - 27017:27017
    volumes:
      - mongo0:/data/db
    restart: always
    entrypoint:
      [
        "/usr/bin/mongod",
        "--bind_ip_all",
        "--replSet",
        "rs0",
        "--journal",
        "--enableMajorityReadConcern",
        "false"
      ]
    networks:
      - mongo_rs
volumes:
  mongo0:
networks:
  mongo_rs:
    name: mongo_rs

但启动时出现

Creating network "mongo_rs" with the default driver
Creating mongo1 ... done
Attaching to mongo1
mongo1    | {"t":{"$date":"2022-05-12T00:09:25.151Z"},"s":"F",  "c":"CONTROL",  "id":5324700, "ctx":"-","msg":"** ERROR: Starting in 5.0, disabling enableMajorityReadConcern setting is no longer available because of MongoDB's resiliency enhancements. If your environment was previously running with eMRC=f, please see https://docs.mongodb.com/v5.0/reference/read-concern-majority/#disable-read-concern-majority"}

查了一下这是因为5.0版本开始强制开启了read concern majority
在这里插入图片描述
read concern majority保证了读取到的数据一定是已经写入了主要的主要副本集节点中,所以能够避免脏读。
在这里插入图片描述
所以需要将上面docker-compose.yml中的entrypoint改为

...
    entrypoint:
      [
        "/usr/bin/mongod",
        "--bind_ip_all",
        "--replSet",
        "rs0",
        "--journal"
      ]
...

一切就正常了,最后顺利升级到5.0.8
在这里插入图片描述
参考:
https://www.mongodb.com/docs/manual/reference/versioning/
https://www.mongodb.com/docs/v5.0/reference/read-concern-majority/#disable-read-concern-majority
https://www.mongodb.com/docs/v5.0/reference/program/mongod/#std-option-mongod.–enableMajorityReadConcern

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-05-13 11:48:46  更:2022-05-13 11:49:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 5:52:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码