当前位置: 首页 > news >正文

MongoDB副本集搭建

版本

> db.version()
4.4.24
> 

集群相关命令

rs.status()## id 要和配置文件定义的replSetName一致
cfg={_id:"knight",members:[{_id:0,host:'182.27.239.17:27017',priority:1}]}##  id 要和配置文件定义的replSetName一致
cfg={_id:"knight",members:[{_id:0,host:'10.1.1.32:27017',priority:1},{_id:1,host:'10.1.1.33:27017',priority:0,votes:0}]}##
cfg={_id:"knight",members:[{_id:0,host:'10.1.1.32:27017',priority:1},{_id:1,host:'10.1.1.33:27017',priority:0}]}## 
rs.initiate(cfg)  ## 查看配置
rs.conf()###
rs.reconfig(config,{force:true})### 查看配置
rs.config()
rs.config().members

参考

##
https://blog.csdn.net/GotFull/article/details/127034877### 副本集无效
https://www.coder.work/article/544115

配置文件

systemLog:destination: filepath: "/opt/app/mongodb_cluster/log/m27071.log"logAppend: true
processManagement:fork: truepidFilePath: "/opt/app/mongodb_cluster/pid/m27071.pid"
net:port: 27017bindIp: 0.0.0.0
#   http:
#     enabled: true
#     RESTInterfaceEnabled: truestorage:dbPath: "/opt/app/data/27071"engine: wiredTigerjournal:enabled: truedirectoryPerDB: truewiredTiger:engineConfig:cacheSizeGB: 1directoryForIndexes: true# 定义复制集的名称
replication:oplogSizeMB: 800replSetName: "rs"

集群配置

初始化

在主节点上执行命令如下:

# 执行命令
rs.initiate()####
#若客户端返回信息中字段OK的值为1,说明成功初始化副本集。
#完成初始化命令,当前节点默认处于"SECONDARY(副本节点)"状态.
###等待几秒后,按回车键。自动选举自己为PRIMARY(主节点)

添加成员节点

## 先默认初始化
rs.initiate()   ## 
cfg={_id:"xbrother",members:[{_id:0,host:'10.1.1.32:27017',priority:1},{_id:1,host:'10.1.1.33:27017',priority:0}]}##
rs.initiate(cfg)   

检查和测试

# 检查状态
rs.status()## 主节点写入数据测试
rs:PRIMARY> db.user.insert({"name":"knight","age":30})
WriteResult({ "nInserted" : 1 })
rs:PRIMARY> db.user.find()
{ "_id" : ObjectId("64f9b892e61da94af298a9d3"), "name" : "knight", "age" : 30 }
rs:PRIMARY> ### 从节点查询数据
#### 从库开启读
rs:SECONDARY> rs.secondaryOk()##
rs:SECONDARY> use test
switched to db test
rs:SECONDARY> db.user.find()
{ "_id" : ObjectId("64f9b892e61da94af298a9d3"), "name" : "knight", "age" : 30 }
rs:SECONDARY> 

http://www.lryc.cn/news/165896.html

相关文章:

  • 【面试】Redis的热key问题如何发现和解决?
  • LeetCode-热题100-笔记-day21
  • Spring框架中的@Conditional系列注解
  • spring boot + minio 8.5.4 遇到 okhttp3包冲突
  • springboot整合actuator、admin对应用程序进行监控
  • 文举论金:黄金原油全面走势分析策略指导。
  • Fedora CoreOS 安装部署详解
  • Web应用开发 - 实训三 B Servlet基础
  • Debian12安装 Docker
  • Elasticsearch:为具有许多 and/or 高频术语的 top-k 查询带来加速
  • 【pythonflask-1】简单实现加减乘除输入界面
  • 基于协同过滤算法的旅游推荐系统
  • 遇见问题:使用mybaties向数据库中插入数据,idea显示插入成功,但是数据库中并没有数据变化?
  • markdown学习笔记
  • C++项目实战——基于多设计模式下的同步异步日志系统-⑧-日志落地类设计
  • 从零开始探索C语言(八)----指针
  • SpringMVC 的三种异常处理方式详解
  • 莫比乌斯召回系统介绍
  • 使用ASM修改组件化 ARouter
  • 第21章_瑞萨MCU零基础入门系列教程之事件链接控制器ELC
  • (二十八)大数据实战——Flume数据采集之kafka数据生产与消费集成案例
  • vue3:22、vue-router的使用
  • 深入理解JVM虚拟机第五篇:一些常用的JVM虚拟机(二)
  • 导数公式及求导法则
  • SpringMVC系列(六)之JSON数据返回以及异常处理机制
  • 民安智库(北京第三方窗口测评)开展汽车消费者焦点小组座谈会调查
  • 【CVPR2021】MVDNet论文阅读分析与总结
  • IDEA指定Maven settings file文件未生效
  • swift UI 和UIKIT 如何配合使用
  • c语言练习题55:IP 地址⽆效化