MongoDB集群搭建及使用(mongos集群)
itomcoil 2025-06-08 21:51 10 浏览
作者:doremi
mongodb的集群搭建方式主要有三种,主从模式,Replicaset模式,sharding模式,三种模式各有优劣,适用于不同的场合,属Replicaset应用最为广泛,主从模式现在用的较少,sharding模式最为完备,但配置维护较为复杂。本文我们来看下ReplicaSet模式的搭建方法。
Mongodb的ReplicaSet即副本集方式主要有两个目的,一个是数据冗余做故障恢复使用,当发生硬件故障或者其它原因造成的宕机时,可以使用副本进行恢复。另一个是做读写分离,读的请求分流到副本上,减轻主(Primary)的读压力。
ReplicaSet是mongod的实例集合,它们有着同样的数据内容。包含三类角色:
(1)主节点(Primary)
接收所有的写请求,然后把修改同步到所有Secondary。一个ReplicaSet只能有一个Primary节点,当Primary挂掉后,其他Secondary或者Arbiter节点会重新选举出来一个主节点。默认读请求也是发到Primary节点处理的,需要转发到Secondary需要客户端修改一下连接配置。
(2)副本节点(Secondary)
与主节点保持同样的数据集。当主节点挂掉的时候,参与选主。
(3)仲裁者(Arbiter)
不保有数据,不参与选主,只进行选主投票。使用Arbiter可以减轻数据存储的硬件需求,Arbiter跑起来几乎没什么大的硬件资源需求,但重要的一点是,在生产环境下它和其他数据节点不要部署在同一台机器上。
注意,一个自动failover的ReplicaSet节点数必须为奇数,目的是选主投票的时候要有一个大多数才能进行选主决策。
(4)选主过程
其中Secondary宕机,不受影响,若Primary宕机,会进行重新选主:
####使用Arbiter搭建ReplicaSet
偶数个数据节点,加一个Arbiter构成的ReplicaSet方式:
搭建集群
#####在/opt下解压mongodb
tar-zxvf mongodb-linux-x86_64-ubuntu1404-3.2.4
创建数据目录
mkdir-p data/mongodb/{master,slave,arbiter}
#####二、创建配置文件
主节点:vi/etc/mongodb_master.conf
#master.conf
dbpath=/opt/data/mongodb/master
logpath=/opt/mongodb/master.log
pidfilepath=/opt/mongodb/master.pid
#keyFile=/opt/mongodb/mongodb.key
directoryperdb=true
logappend=true
replSet=testdb
bind_ip=192.168.255.141
port=27017
#auth=true
oplogSize=100
fork=true
noprealloc=true
#maxConns=4000
备份节点:vi/etc/mongodb_slave.conf
#slave.conf
dbpath=/opt/data/mongodb/slave
logpath=/opt/mongodb/slave.log
pidfilepath=/opt/mongodb/slave.pid
#keyFile=/opt/mongodb/mongodb.key
directoryperdb=true
logappend=true
replSet=testdb
bind_ip=192.168.255.142
port=27017
#auth=true
oplogSize=100
fork=true
noprealloc=true
#maxConns=4000
仲裁点:vi/etc/mongodb_arbiter.conf
#arbiter.conf
dbpath=/opt/data/mongodb/arbiter
logpath=/opt/mongodb/arbiter.log
pidfilepath=/opt/mongodb/arbiter.pid
#keyFile=/opt/mongodb/mongodb.key
directoryperdb=true
logappend=true
replSet=testdb
bind_ip=192.168.255.142
port=27019
#auth=true
oplogSize=100
fork=true
noprealloc=true
#maxConns=4000
备注:
keyFile和auth选项要在集群配置好后,并且添加了验证用户后在启用
参数说明:
dbpath:存放数据目录
logpath:日志数据目录
pidfilepath:pid文件
keyFile:节点之间用于验证文件,内容必须保持一致,权限600,仅ReplicaSet 模式有效
directoryperdb:数据库是否分目录存放
logappend:日志追加方式存放
replSet:ReplicaSet的名字
bind_ip:mongodb绑定的ip地址
port:端口
auth:是否开启验证
oplogSize:设置oplog的大小(MB)
fork:守护进程运行,创建进程
moprealloc:是否禁用数据文件预分配(往往影响性能)
maxConns:最大连接数,默认2000
#####三、启动mongodb
/opt/mongodb/bin/mongod-f /etc/mongodb_master.conf
/opt/mongodb/bin/mongod-f /etc/mongodb_slave.conf
/opt/mongodb/bin/mongod-f /etc/mongodb_arbiter.conf
#####四、在主节点进行配置
连接mongoDB
配置集群
cfg={_id:"testdb", members:[{_id:0,host:'192.168.255.141:27017',priority:2},{_id:1,host:'192.168.255.142:27017',priority:1},{_id:2,host:'192.168.255.142:27019',arbiterOnly:true}]};
rs.initiate(cfg)
说明:
cfg名字可选,只要跟mongodb参数不冲突,_id为ReplicaSet名字,members里面的优先级priority值高的为主节点,对于仲裁点一定要加上arbiterOnly:true,否则主备模式不生效
priority表示优先级别,数值越大,表示是主节点
arbiterOnly:true表示仲裁节点
使集群cfg配置生效rs.initiate(cfg)
查看是否生效rs.status()
"stateStr": "PRIMARY"表示主节点,"stateStr" : "SECONDARY"表示从节点,"stateStr" :"ARBITER",表示仲裁节点
添加节点命令
添加secondary:rs.add({host:"192.168.255.141:27019", priority: 1})
添加仲裁点:rs.addArb("192.168.255.142:27019")
移除节点:rs.remove({host:"192.168.255.141:27019"})
####在iServer中配置使用MongoDB集群
在分布式切图选项中添加MongoDB存储位置
添加之后,开始切图,就可以在mongoDB中看到瓦片已经存储在各个节点中了
发布瓦片服务,浏览地图
相关推荐
- pip 设置镜像源
-
pip是python必不可少的的包管理工具,但是要在国内用得爽,必须要配置镜像源。我常用的是清华镜像站。pipconfigsetglobal.index-urlhttps://pypi...
- 定制构建OpenWrt发行版镜像及插件安装包,升级插件到最新版本
-
最近Tailscale提示OpenWrt路由器上的版本太低,建议升级到最新版本。OpenWrt用的23.05的,因为23.05中带的tailscale版本比较老,之前升级都是从主线版本中下载最新的ta...
- 第十节 Dockerfile 核心指南:从基础概念到镜像构建实践
-
一、Dockerfile基础概念(一)本质与作用Dockerfile是用于定义Docker镜像构建流程的文本文件,包含一系列指令和说明,指导Docker引擎生成定制化镜像。其核心价值在于:...
- Python 模型部署不用愁!容器化实战,5 分钟搞定环境配置
-
你是不是也遇到过这种糟心事:花了好几天训练出的Python模型,在自己电脑上跑得顺顺当当,一放到服务器就各种报错。要么是Python版本不对,要么是依赖库冲突,折腾半天还是用不了。别再喊“我...
- Docker-镜像
-
1、获取镜像在Docker中,获取(下载)镜像通常使用dockerpull命令:基本用法:dockerpull镜像名称[:标签]例如:dockerpullnginx...
- 第十二节 Ubuntu 系统 Docker 镜像安装与容器运行指南
-
一、Ubuntu镜像版本选择(一)DockerHub镜像库浏览Ubuntu官方镜像在DockerHub上提供多版本支持,访问地址:https://hub.docker.com/_/ubu...
- Docker-使用Dockerfile 定制镜像
-
一、什么是Dockerfile?Dockerfile是一个文本文件,其中包含一条条构建镜像所需的指令。Docker引擎会按顺序执行这些指令,逐步构建出最终的自定义镜像。二、Dockerfil...
- 在Windows的WSL环境中本地安装watercrawl和Python3.13
-
这段时间在折腾Dify环境调用网络爬虫工具去自动化抓取网页信息的功能,就希望在本地Windows11的WSL环境中docker方式部署watercrawl,但每次都报错如下:用命令pip--ver...
- 1分钟搞定!Python超速工具uv换国内镜像,下载速度飙升10倍
-
1分钟搞定!Python超速工具uv换国内镜像,下载速度飙升10倍作为搞运维的老手,我太清楚Python包下载速度慢是啥滋味了。今天我来教你用3行代码给uv换上清华或者阿里云的镜像,这样就...
- Dockerfile 教程:构建你的第一个自定义镜像!
-
Dockerfile就是你自定义镜像的“说明书”,学会它,你就能打造属于自己的开发环境、部署环境,甚至可以把你的应用一键打包。一、什么是Dockerfile?Dockerfile是一个文本文件...
- 提升Python编程效率的10点建议
-
程序员的时间很宝贵,Python这门语言虽然足够简单、优雅,但并不是说你使用Python编程,效率就一定会高。要想节省时间、提高效率,还是需要注意很多地方的。今天就与大家分享资深Python程序员总结...
- 掌握线性代数: 奇异值分解 (SVD)
-
奇异值分解(SVD)什么是SVD?奇异值分解是一种矩阵分解方法,它将矩阵A分解为三个分量:哪里:U是正交矩阵(mxm)Σ是包含奇异值(mxn)的对角矩阵V^T是另一个正交矩...
- 用 Docker+K8s 部署模型,再也不怕流量暴增和服务器崩溃了
-
上周朋友公司的AI模型又出问题了——电商大促期间,预测接口突然崩溃,眼睁睁看着订单流失。老板气得拍桌子:“花了几十万训练的模型,连个大促都扛不住?”这其实是很多企业的通病:模型在实验室跑得好好...
- Python 图像处理
-
以前照相从来没有那么容易。现在你只需要一部手机。拍照是免费的,如果我们不考虑手机的费用的话。就在上一代人之前,业余艺术家和真正的艺术家如果拍照非常昂贵,并且每张照片的成本也不是免费的。我们拍照是为了及...
- 一文让你掌握22个神经网络训练技巧
-
作者丨匡吉来源丨深蓝学院神经网络训练是一个非常复杂的过程,在这过程中,许多变量之间相互影响,因此我们研究者在这过程中,很难搞清楚这些变量是如何影响神经网络的。而本文给出的众多tips就是让大家,在神经...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)