mongoDB搭建集群
创始人
2024-05-31 05:46:11
0

(学习自黑马)

下载对应linux版本MongoDB

源码下载地址:https://www.mongodb.com/download-center#community

目前在一台服务器开三个端口模拟三个mongodb,

配置一个主节点27017,

一个从节点27018,

一个仲裁者27019

配置主节点,副节点,仲裁节点

(下面的创建文件一共有三份,通过不同的端口号实现 , 将配置文件的端口修改成对应节点端口即可,注意路径也要跟着修改)

#创建文件log日志文件data数据文件 conf配置文件

mkdir -p /mongodb/replica_sets/myrs_{端口号}/log \ &
mkdir -p /mongodb/replica_sets/myrs_{端口号}/data/db
vim /mongodb/replica_sets/myrs_{端口号}/mongod.conf

mongod.conf文件内容

systemLog:destination: filepath: "/mongodb/replica_sets/myrs_{端口号}/log/mongod.log"logAppend: true
storage:dbPath: "/mongodb/replica_sets/myrs_{端口号}/data/db"journal:#启用或禁用持久性日志以确保数据文件保持有效和可恢复。enabled: true
processManagement:#启用在后台运行mongos或mongod进程的守护进程模式。fork: true#指定用于保存mongos或mongod进程的进程ID的文件位置,其中mongos或mongod将写入其PIDpidFilePath: "/mongodb/replica_sets/myrs_{端口号}/log/mongod.pid"
net:#服务实例绑定所有IP,有副作用,副本集初始化的时候,节点名字会自动设置为本地域名,而不是ip#bindIpAll: true#服务实例绑定的IP 本机ipbindIp: localhost,192.168.0.252  #bindIp#绑定的端口port: {端口号}
replication:#副本集的名称replSetName: myrs

启动mongodb: (三个都要启动)

/{你上传的mongodb路径}/mongod -f 
/mongodb/replica_sets/myrs_{端口号}/mongod.conf

查看启动状态 出现三个服务代表启动成功

ps -ef | grep 'mongo'[root@CentOS7 ~]# ps -ef | grep 'mongo'
root     27598     1  0 10:15 ?        00:00:17 /application/mongoBD/mongodb/bin/mongod -f /mongodb/replica_sets/myrs_27017/mongod.conf
root     29589     1  0 10:59 ?        00:00:06 /application/mongoBD/mongodb/bin/mongod -f /mongodb/replica_sets/myrs_27018/mongod.conf
root     30045     1  0 11:08 ?        00:00:04 /application/mongoBD/mongodb/bin/mongod -f /mongodb/replica_sets/myrs_27019/mongod.conf

进入主节点,这时使用show dbs命令会报错需要执行初始化副本集

rs.initiate()

执行完成后, show dbs 命令成功

添加从节点

rs.add("192.168.0.252:27018")

查看状态

rs.status()

members里面即为集群配置

"members" : [{"_id" : 0,"name" : "192.168.0.252:27017","health" : 1,"state" : 1,"stateStr" : "PRIMARY","uptime" : 4840,"optime" : {"ts" : Timestamp(1678332988, 1),"t" : NumberLong(1)},"optimeDate" : ISODate("2023-03-09T03:36:28Z"),"syncingTo" : "","syncSourceHost" : "","syncSourceId" : -1,"infoMessage" : "","electionTime" : Timestamp(1678331608, 1),"electionDate" : ISODate("2023-03-09T03:13:28Z"),"configVersion" : 2,"self" : true,"lastHeartbeatMessage" : ""},{"_id" : 1,"name" : "192.168.0.252:27018","health" : 1,"state" : 2,"stateStr" : "SECONDARY","uptime" : 40,"optime" : {"ts" : Timestamp(1678332988, 1),"t" : NumberLong(1)},"optimeDurable" : {"ts" : Timestamp(1678332988, 1),"t" : NumberLong(1)},"optimeDate" : ISODate("2023-03-09T03:36:28Z"),"optimeDurableDate" : ISODate("2023-03-09T03:36:28Z"),"lastHeartbeat" : ISODate("2023-03-09T03:36:34.887Z"),"lastHeartbeatRecv" : ISODate("2023-03-09T03:36:34.099Z"),"pingMs" : NumberLong(0),"lastHeartbeatMessage" : "","syncingTo" : "192.168.0.252:27017","syncSourceHost" : "192.168.0.252:27017","syncSourceId" : 0,"infoMessage" : "","configVersion" : 2}]

添加仲裁节点

rs.addArb("192.168.0.252:27019") 

此时在查看状态members里面会多出仲裁节点

登录从节点

/{路径}/bin/mongo --host 192.168.0.252 --port=27018

此时使用show dbs报错

设置为从节点

rs.slaveOk()

此时使用show dbs 成功 现在可实现了读写分离,让主插入数据,让从来读取数据

登录仲裁者节点

/{路径}/bin/mongo --host 192.168.0.252 --port=27019

设置为仲裁节点

rs.slaveOk()

完成

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...