(保姆级)离线安装mongoDB集群

Docker搭建MongoDB集群

副本集模式(Replica Set)

  • 是一种互为主从的关系, Replica Set 将数据复制多份保存,不同服务器保存同一份数据,在出现故障时自动切换,实现故障转移。

  • 此集群拥有一个主节点和多个从节点,这一点与主从复制模式类似,且主从节点所负责的工作也类似,但是副本集与主从复制的区别在于:当集群中主节点发生故障时,副本集可以自动投票,选举出新的主节点,并引导其余的从节点连接新的主节点,而且这个过程对应用是透明的。

准备:离线环境安装docker

参考:

一 、Docker部署MongoDB集群(Replica Set模式-单台)

mongodb版本信息:MongoDB shell version v5.0.5MongoDB server version: 5.0.5单台的集成了一下shell脚本,多台的是分开的,一步一步的。

(1)镜像下载

docker pull mongo:5.0.5内网打包镜像成tar
docker save -o <导出的文件名.tar> <镜像名称:标签>docker save -o mongo.tar mongo:5.0.5
将tar包放入/opt/docker/下
导入镜像:
docker load -i myimage.tar
查看:
docker images

(2)建立集群网络和集群

#!/bin/bash
for conf in 27018_mongo-master 27019_mongo-slave 27020_mongo-arbiter; do \echo "conf len= ${#conf}, port=${conf:0:5}, name=${conf:6:${#conf}}";if [ ${conf:0:5} == 27018 ]thendocker network create mongo-networkecho "create mongo-network"fidocker run -d --restart=always \-p ${conf:0:5}:27017 \--name ${conf:6:${#conf}} \-v /opt/mongo/${conf:6:${#conf}}/configdb/:/data/configdb \-v /opt/mongo/${conf:6:${#conf}}/db/:/data/db \-v /opt/mongo/${conf:6:${#conf}}/backup:/data/backup \--net=mongo-network \mongo:5.0.5 \mongod --dbpath /data/db --replSet mongoreplset
done

(3)配置集群

设置MongoDB的复制集(Replica Set)的配置信息

1. 进入master容器中的mongo:docker exec -it mongo-master mongo
2. 配置集群:IP为部署数据库的服务器IP,例如IP是10.9.21.12 (防火墙端口要放开)
config = {_id:"mongoreplset", version:1, members:[{_id:0, host:"10.9.21.12:27018", priority:5}, {_id:1, host:"10.9.21.12:27019", priority:2}, {_id:2, host:"10.9.21.12:27020", priority:3}]}rs.initiate(config)如果提示错误,且rs.config()后查看已经有配置,但未实现主从,则可尝试执行下面的代码,重新配置(force -> 非主节点强制请求重新分配主节点。)
[errmsg” : “New config is rejected :: caused by :: replSetReconfig should only be run on a writable PRIMARY. Current state REMOVED;”]rs.reconfig({_id:"mongoreplset", version:1, members:[{_id:0, host:"10.9.21.12:27018", priority:5}, {_id:1, host:"10.9.21.12:27019", priority:2}, {_id:2, host:"10.9.21.12:27020", priority:3}]},{force:true})3. 退出: exit4. 验证集群配置:docker exec -it mongo-master mongo会有如下提示:mongoreplset:PRIMARY> docker exec -it mongo-slave mongo会有如下提示:mongoreplset:SECONDARY>docker exec -it mongo-arbiter mongo会有如下提示:mongoreplset:SECONDARY>

(4)创建数据库用户

1. 进入master容器中的mongo:docker exec -it mongo-master mongo
2. 创建用户:
use admin
db.createUser({user: "root",pwd: "db_root_password",roles: ["root"]})   
db.auth("root", "Synjones2021") //测试一下
db.createUser({user: "user01",pwd: "db_user01_password",roles: ["readWriteAnyDatabase"]})   
exit

(5)mongodb集群的连接地址

如下:
mongodb://user01:db_user01_password@10.9.21.12:27018,10.9.21.12:27019,10.9.21.12:27020

(6)删除集群

docker ps -adocker stop id1/id2/id3  三个都停止docker rm -f id1/id2/id3 docker network lsdocker network rm network_idrm -rf /opt/mongo/..(建立集群时配置的目录)

(7)备份原数据库文件

1.进入原mongo容器: docker exec -it mongodb bash2.备份原mongo库:mongodump --host 10.9.21.12 --port 27017 -u username -p password -o /data/backup --authenticationDatabase admin3.停掉原mongo容器(如果部署在同一台端口冲突可先停掉): docker stop mongodb4.拷贝备份文件(从容器内拷贝到本机):
【 docker cp <container_id>:/data/db/. /path/to/local/directory 】
/data/db/.表示拷贝/data/db目录及其所有内容,包括子目录和文件
docker cp 70161373fcef:/data/backup/. /opt/mongo/mongo-master/backup(此路径为创建容器时设置的容器、本机共享账户)5. 进入容器内可查看到已经将文件共享进来了ls -lh
6. 进入master容器中:docker exec -it mongo-master bash
7. 加载备份数据:mongorestore --host 10.9.21.12  --port 27018 /data/backup/
8. 退出:exit

二、Docker部署MongoDB集群(Replica Set模式-多台)

假设一共有两台机器:10.9.21.13(主)、10.9.21.11(从)

(0)镜像打包 导入

docker pull mongo:5.0.5内网打包镜像成tar
docker save -o <导出的文件名.tar> <镜像名称:标签>docker save -o mongo.tar mongo:5.0.5
将tar包放入/opt/docker/下,
导入镜像:
docker load -i myimage.tar
查看:
docker images

(1)建立数据库集群网络

假设一共有两台机器:10.9.21.13(主)、10.9.21.11(从),两台机器均要创建 mongo-network
docker network ls
docker network create mongo-network
——————————————————————————
docker network rm network_id //删除

(2)建立集群

假设一共有两台机器:10.9.21.13(主)、10.9.21.11(从)

启动容器,并配好参数(整理为shell脚本 执行脚本)

10.9.21.13(主)
#!/bin/bash
docker run -d --restart=always \
-p 27017:27017 \
--name mongo-master \
-v /opt/mongo/mongo_master/configdb/:/data/configdb \
-v /opt/mongo/mongo_master/db/:/data/db \
-v /opt/mongo/mongo_master/backup:/data/backup \
--net=mongo-network \
mongo:5.0.5 \
mongod --dbpath /data/db --replSet mongoreplset
10.9.21.11(从)
拷贝备份文件进入-v /opt/mongo/mongo-slave/backup(如果需要)
可参考:进入备份文件夹backup:zip -r ttt.zip *跨机器拷贝:scp /opt/x/backup/tt.zip @10.9.21.13:/opt/mongo/mongo_master/backup解压:unzip tt.zip#!/bin/bash
docker run -d --restart=always \
-p 27018:27017 \
--name mongo-slave \
-v /opt/mongo/mongo-slave/configdb/:/data/configdb \
-v /opt/mongo/mongo-slave/db/:/data/db \
-v /opt/mongo/mongo-slave/backup:/data/backup \
--net=mongo-network \
mongo:5.0.5 \
mongod --dbpath /data/db --replSet mongoreplset#!/bin/bash
docker run -d --restart=always \
-p 27019:27017 \
--name mongo-arbiter \
-v /opt/mongo/mongo-arbiter/configdb/:/data/configdb \
-v /opt/mongo/mongo-arbiter/db/:/data/db \
-v /opt/mongo/mongo-arbiter/backup:/data/backup \
--net=mongo-network \
mongo:5.0.5 \
mongod --dbpath /data/db --replSet mongoreplset

(3)配置集群

1. 进入master容器:docker exec -it mongo-master bash
2. 进入mongo:mongo
3. 配置集群:IP为部署数据库的服务器IP
config = {_id:"mongoreplset", version:1, members:[{_id:0, host:"10.9.21.13:27017", priority:5}, {_id:1, host:"10.9.21.11:27018", priority:2}, {_id:2, host:"10.9.21.11:27019", priority:3}]}
rs.initiate(config)
4. 退出mongo:exit
5. 加载旧库的备份数据(如果需要,将3.1备份的数据拷贝到主机相应的挂载目录):mongorestore --host <mongo主Ip> --port 27017 /data/backup/
6. 退出容器: exit
7. 验证集群:10.9.21.13(主) docker exec -it mongo-master mongo会有如下提示:mongoreplset:PRIMARY> 10.9.21.11(从) docker exec -it mongo-slave mongo会有如下提示:mongoreplset:SECONDARY>10.9.21.11(从) docker exec -it mongo-arbiter mongo会有如下提示:mongoreplset:SECONDARY>

(4)导入备份数据

1. 进入master容器中:docker exec -it mongo-master bash
2. 进入容器内能看到共享文件夹内的备份文件cd /data/backup	ls -lh
3. 加载备份数据:mongorestore --host   10.9.21.13 --port 27018 /data/backup/

(5)链接查看

use admindb.auth("username", "password") //测试一下链接:
mongodb://user01:db_user01_password@10.9.21.12:27018,10.9.21.12:27019,10.9.21.12:27020

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/757213.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【单点知识】基于实例讲解PyTorch中的Transforms类

文章目录 0. 前言1. 基本用法1.1 转换为Tensor1.2 图像大小调整1.3 随机裁剪1.4 中心裁剪1.5 随机翻转1.6 随机旋转1.7 填充1.8 组合变换 2. 进阶用法2.1 归一化2.2 色彩空间转换2.3 颜色抖动2.4 随机仿射2.5 透视变换2.6 自定义变换 0. 前言 按照国际惯例&#xff0c;首先声明…

Spring Data访问Elasticsearch----路由值Routing values

Spring Data访问Elasticsearch----路由值Routing values 一、join-types的路由二、自定义路由值 当Elasticsearch将文档存储在具有多个分片的索引中时&#xff0c;它会根据文档的id确定要使用的分片。有时有必要预先定义多个文档应该在同一个shard上建立索引&#xff08;join-t…

Day51-Nginx多实例知识与大厂企业级实战

Day51-Nginx多实例知识与大厂企业级实战 1. 什么是nginx多实例&#xff1f;2. 为什么要用多实例&#xff1f;3. 大厂数百个业务项目&#xff0c;如何来管理&#xff1f;4. 大厂上百项目web分用户解决方案4.1 编译nginx环境实践&#xff1a;4.2 zuma实例(利用普通用户权限将不同…

LeetCode题练习与总结:组合总和Ⅱ

一、题目 给定一个候选人编号的集合 candidates 和一个目标数 target &#xff0c;找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字在每个组合中只能使用 一次 。 注意&#xff1a;解集不能包含重复的组合。 二、解题思路 排序&#xff1a…

前端项目,个人笔记(二)【Vue-cli - 引入阿里矢量库图标 + 吸顶交互 + setup语法糖】

目录 1、项目中引入阿里矢量库图标 2、实现吸顶交互 3、语法糖--<script setup> 3.1、无需return 3.2、子组件接收父组件的值-props的使用 3.3、注册组件 1、项目中引入阿里矢量库图标 步骤一&#xff1a;进入阿里矢量库官网中&#xff1a;iconfont-阿里巴巴矢量…

教务管理系统(java+mysql+jdbc+Druid+三层架构)

1、项目要求 1.1数据库表描述 设计一个教务管理系统&#xff0c;要求如下&#xff1a; 系统涉及的表有 account表&#xff08;账号表&#xff09; teacher表&#xff08;教师表&#xff09; student表&#xff08;学生表&#xff09; course表 (课程表) score表&#xff08;成…

拦截器(springboot)

1、拦截器介绍 在SpringBoot中&#xff0c;拦截器是一种用于拦截请求并在处理请求之前或之后执行特定操作的机制。 拦截器可以用于实现一些通用的功能&#xff0c;例如身份验证、日志记录、性能监控等。 Springboot中的拦截器是通过实现HandlerInterceptor接口来实现的&#x…

[Halcon学习笔记]机器视觉缺陷检测常用方法对比总结

1、介绍 缺陷检测时机器视觉需求中最复杂难度较大的一类需求。究其原因&#xff0c;主要是在项目开发过程中首先要保证检测的稳定性和精度&#xff0c;又要实现缺陷检测的通用性&#xff0c;常见的缺陷&#xff1a;凹凸、污点瑕疵、划痕、裂缝、伤痕、毛刺等等类型种类繁杂&am…

uniapp 使用sqlite时无法读取到db文件中的数据

问题 {“code”:-1404,“message”:“android.database.sqlite.SQLiteException: no such table: user (Sqlite code 1): , while compiling: select * from user, (OS error - 2:No such file or directory),http://ask.dcloud.net.cn/article/282”} at pages/index/index.vu…

Python内置对象

Python是一种强大的、动态类型的高级编程语言&#xff0c;其内置对象是构成程序的基础元素。Python的内置对象包括数字、字符串、列表、元组、字典、集合、布尔值和None等&#xff0c;每种对象都有特定的类型和用途。 01 什么是内置对象 这些对象是编程语言的基础构建块&…

STP环路避免实验(思科)

华为设备参考&#xff1a;STP环路避免实验&#xff08;华为&#xff09; 一&#xff0c;技术简介 Spanning Tree Protocol&#xff08;STP&#xff09;&#xff0c;即生成树协议&#xff0c;是一种数据链路层协议。主要作用是防止二层环路&#xff0c;并自适应网络变化和故障…

【AI案例】做AI视频如何实现数字人实时口型同步

首先,这个方案提供了一个令人瞩目的实时唇语同步API。这一技术能够将任何视频与任何语言的音频进行视觉配音,而且无需繁琐的训练过程。这样的功能极大地拓宽了视频内容的传播范围,使得无论语言背景如何,人们都能够理解并享受视频内容。 其次,这个API的适用性非常广泛,无…

Unity2D实现鼠标拖动物体移动(简单好抄)

1.新建脚本&#xff0c;并将脚本拖到你想要拖动的物体上即可 using System.Collections; using System.Collections.Generic; using Unity.VisualScripting; using UnityEngine;public class text : MonoBehaviour {private Vector3 offset;public int x 1;void OnMouseDown(…

第十三届“中关村青联杯”全国研究生数学建模竞赛-A题:多无人机协同任务规划(续)

目录 7.2 模型三的建立与求解 8 问题四:针对远程雷达的分步优化模型 9 问题五:模型分析

【Pandas】(2)DataFrame

Pandas 的 DataFrame 是一个二维的、大小可变的、异质型表格数据结构,带有标签化的轴(行和列)。简单来说,你可以将 DataFrame 看作是一个 Excel 表格或 SQL 数据表,在数据分析和数据处理中非常有用。 创建 DataFrame DataFrame 可以通过多种方式创建,最常用的是直接从字…

SAP前台处理:物料主数据创建<MM01>之销售视图

一、背景&#xff1a; 终于来到了物料主数据&#xff0c;我觉得物料账是SAP最重要的一项发明&#xff0c;也一直是SAP的一项重要优势&#xff0c;物料账记录了一个个物料的生生不息&#xff1b; 本章主要讲解物料主数据和财务相关的主要内容&#xff1a;这里特别提示由于作者…

matlab软件基础

第1讲 MATLAB初步 MATLAB是矩阵实验室&#xff08;Matrix Laboratory&#xff09;的简称&#xff0c;是美国MathWorks公司出品的商业数学软件&#xff0c;用于算法开发、数据可视化、数据分析以及数值计算的高级技术计算语言和交互式环境。MATLAB和Mathematica、Maple并称为三…

Linux 发布项目到OpenEuler虚拟机

后端&#xff1a;SpringBoot 前端&#xff1a;VUE3 操作系统&#xff1a;Linux 虚拟机&#xff1a;OpenEuler 发布项目是需要先关闭虚拟机上的防火墙 systemctl stop firewalld 一、运行后端项目到虚拟机 1、安装JDK软件包 查询Jdk是否已安装 dnf list installed | grep jd…

Redis数据结构对象中的类型检查与命令多态、内存回收

类型检查与命令多态 概述 redis中用于操作键的命令基本上可以分为两种类型。其中一种命令可以对任何类型的键执行&#xff0c;比如说DEL命令、EXPIRE命令、RENAME命令、TYPE命令、OBJECT命令等. 而另一种命令只能对特定类型的键执行&#xff0c;比如说 1.SET、GET、APPEND、…

OPTEE v3.20.0 FVP环境搭建

目录 一、前提条件 二、下载fvp代码 三、下载工具链 四、下载Foundation_Platform FVP平台 五、编译及运行 一、前提条件 1、安装如下的依赖工具 sudo apt-get install android-tools-adb android-tools-fastboot autoconf \ automake bc bison build-essential ccache c…