mongodb副本集_设置MongoDB副本集分为4个步骤

mongodb副本集

介绍

在详细介绍配置MongoDB副本集之前,让我简要介绍一下它们:

  • 副本集是Mongodb数据库提供的功能,可实现高可用性和自动故障转移。
  • 它是一种传统的主从配置,但具有自动故障转移功能。
  • 基本上,它是mongod实例的组/集群,它们相互通信,相互复制以提供高可用性并进行自动故障转移
  • 基本上,副本集中至少存在2个,最多可以存在12个mongod实例
  • 在副本集中,存在以下类型的服务器。 首先,一台服务器始终是主要服务器。
    • Primary:存储数据,所有写/读操作均从任何客户端进行到该服务器。
  • 它提供了自动故障转移功能,这意味着它无需人工干预即可将另一台服务器设置为主服务器,并且具有内部机制来选举新的主服务器。
  • 在副本集中,如果主服务器由于网络错误而停机,或者副本集中的其他服务器无法访问主服务器,或者主服务器变得无响应,则由所有服务器在内部触发选举新的主服务器的选择机制,这是非常自动的。

在本文中,我将通过4个简单步骤向您展示3个成员/节点群集副本集的配置。 在此副本集配置中,我们将创建两台数据服务器,其中一台将为主服务器,另一台将为辅助服务器,而另一台非仲裁服务器。 因此,让我们继续按照以下4个步骤配置副本:

步骤1:设置副本集的每个实例

正如我在上一篇文章中讨论的那样,使用以下信息创建和设置3个新的mongodb服务器实例实例,但不要启动这些服务器实例:

  • 服务器1
port = 27017directory path =<dir path>\ rs1E.g.directory structure :  I:\workspace\mongo\rs1\bin
  • 服务器2
port = 26017directory path =<dir path>\ rs2E.g.directory structure  I:\workspace\mongo\rs2\bin
  • 服务器3
port = 25017directory path =<dir path>\ rs2E.g.directory structure  I:\workspace\mongo\rs3\bin

步骤2:修改mongodb.conf以包括副本集信息

编辑每个服务器的mongod.conf以包括以下属性:

  • replSet =副本集的唯一名称,赋予所有成员
  • rest =为管理网页启用休息界面

您可以为副本集指定任何名称,但请确保所有成员名称相同。 继续给你想要的名字。 在这里,我使用的是“ damon”

例如,将以下内容追加到mongod.conf文件中

replSet=damon
rest=true

第三步:启动所有服务器

完成必要的配置后,继续以任意顺序启动服务器

rs1 >> mongod -f \rs1\mongod.conf
rs2 >> mongod -f \rs2\mongod.conf
rs3 >> mongod -f \rs3\mongod.conf

步骤4:配置服务器以包含在副本集中

现在,所有服务器都已启动,但它们没有相互连接。 换句话说,它们不是副本集的一部分。 因此,为此,我们需要执行以下操作。 同样,我们将创建两个数据服务器,即一个主服务器,另一个辅助服务器和一个仲裁服务器。 现在,使用MongoDB二进制文件中提供的mongo shell连接到任何一台服务器。

这里。 让我们使用mongodb shell连接到服务器rs1

rs1 > /rs1/bin/mongo.exe --port 27017

之后,您将得到提示,请输入mongo shell,如下图所示:

png; base645e9fd8342dd15fa1

对于副本配置,mongo shell提供了预定义的对象rs,其中包含以下用于配置的功能:

  • initiate() =>在当前服务器中创建副本集配置
  • status() =>给出服务器所属的副本集的当前状态
  • add(serverInfo) =>在副本集中添加新服务器(作为参数提供)。
  • addArb(serverInfo) =>用于在副本集中添加仲裁器的专用功能

首先,我们需要在其中一台服务器中创建副本集配置。 在mongo shell中执行以下命令:

> rs.initiate()

之后,您会在提示符下看到以下内容:

png; base64838a3d5dc722c104

这将在本地为此服务器创建必要的副本集信息,并且您会注意到提示从初始的'>'更改为'damon:STARTUP2>' ,这表明<replicaSetName:服务器的状态>

您可以在shell提示符下输入rs.status()来检查副本集中有多少台服务器:

png; base642ef0ef96d4cc2826

如您所见,我们在副本集中仅添加了一个服务器,它是当前服务器,其状态为“主要”。

检查副本中成员的其他方法是使用浏览器地址栏中的以下URL http:// : / _replSet。 在我们的例子中,http:// localhost:28017 / _replSet
请注意,这需要在配置文件中启用rest = true(我们已经做到了!)。 这是检查副本集中服务器状态的首选方法。

png; base648c9b0542e15ba78

现在,我们在副本服务器中添加了一个服务器,让我们添加其余服务器。

对于add()addArb()方法,我们将提供包含<machine / host-name>的字符串参数:<port-no-of-server>

(请注意,如果要使用计算机名,请在dos或bash shell中使用hostname命令)

rs.add(“<machine/host-name>:26017”)

png; base6451a8e8144fb9bf78

rs.addArb(“<machine/host-name>:25017”)

png; base6471cda960ad51ffc4

让我们检查是否使用rs.status()命令添加了节点/成员:

png; base64bc2381387562ac74

或使用基于浏览器的:

png; base64281be3bd5613c0e2

在这里,我们配置了3节点副本集MongoDB数据库集群。 尽管此信息可以应用于配置任何编号。 副本集中节点的数量。

参考: 设置MongoDB副本在 另一个Java Duke博客上,从我们的JCG合作伙伴 Abhijeet Sutar 分为4个步骤进行设置 。

翻译自: https://www.javacodegeeks.com/2013/07/setup-mongodb-replica-set-in-4-steps.html

mongodb副本集

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

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

相关文章

JAVA类的继承、覆写和final关键字

extends不用多说&#xff0c;是来继承的关键字&#xff0c;但它有几个要点&#xff1a; java不允许多重继承(一个类只能继承一个父类,不能继承多个父类)派生类会继承基类所有属性和方法,但不能直接访问基类的private私有属性实例化派生类时,会先去调用父类的构造方法构造基类,…

Spring Boot:使用Thymeleaf布局方言的Thymeleaf模板装饰器

介绍 在所有Thymeleaf模板上重用页眉和页脚的问题经常在StackOverflow上提出。 在本文中&#xff0c;我将向您展示如何使用Thymeleaf布局方言来结构化模板&#xff0c;以在Spring Boot应用程序中实现更高的代码可重用性。 创建一个Spring Boot应用程序 让我们使用Spring Initi…

猫、狗与Java的多态

多态&#xff08;Polymorphism&#xff09;按字面的意思就是“多种状态”。在面向对象语言中&#xff0c;接口的多种不同的实现方式即为多态。引用Charlie Calverts对多态的描述——多态性是允许你将父对象设置成为一个或更多的他的子对象相等的技术&#xff0c;赋值之后&#…

solr crud_Spring Data Solr教程:CRUD(差不多)

solr crud在我的Spring Data Solr教程的上一部分中&#xff0c;我们学习了如何配置Spring Data Solr。 现在该迈出一步&#xff0c;了解我们如何管理Solr实例中存储的信息。 此博客文章描述了我们如何向Solr索引添加新文档&#xff0c;如何更新现有文档的信息以及如何从索引中删…

子类覆盖父类(Java)

要求&#xff1a;尝试创建一个父类&#xff0c;在父类中创建两个方法&#xff0c;在子类中覆盖第二个方法&#xff0c;再为子类创建一个对象&#xff0c;将它向上转型并调用这个方法 由于Java里面没有虚函数&#xff0c;所以它的多态是可以被继承的 public class tyu{public …

在Java中进行输入验证时用错误通知替换异常

在我以前的文章中&#xff0c;我写了一个输入验证设计&#xff0c;该设计取代了难以维护和测试的 if-else块。 但是&#xff0c;正如某些读者指出的那样&#xff0c;它有一个缺点–如果输入数据有多个验证错误&#xff0c;则用户将不得不多次提交请求以查找所有错误。 从可用性…

Java构建子类对象时的顺序

先看一个这么的程序&#xff1a; //------------------------------------------------------------------------// //程序目的&#xff0c;创建一个父类与子类&#xff0c;分别创建构造方法 public abstract class usecase1 {abstract void testAbstract();usecase1(){//&…

关于Java中serialUID的序列化的问题

在我们平时处理JAVA类中的问题时&#xff0c;有时会碰见类似这样的一行代码&#xff1a; private static final long serialVersionUID 1L;这就是程序的序列化ID 所谓序列化&#xff0c;用一句通俗的话来说&#xff0c;就是将对象冻结了放入硬盘的过程&#xff0c;举一个例子…

java 绑定微信号开发_Java开发中的常见危险信号

java 绑定微信号开发在开发&#xff0c;阅读&#xff0c;复审和维护成千上万行Java代码的几年中&#xff0c;我已经习惯于看到Java代码中的某些“ 危险信号 ”&#xff0c;这些信号通常&#xff08;但可能并非总是&#xff09;暗示着代码有问题。 我不是在谈论总是错误的做法&a…

使用绝对布局的方法创建一个登录密码验证的简易窗口

绝对布局是指直接采用坐标指定的方式在容器中创建窗口&#xff0c;这种方式比较灵活 采用这种方法创建布局的方式主要有以下几步&#xff1a; 使用Container.setLayout(null)的方式取消布局管理器使用Compon.setBounds()的方式来设置每个组件的大小 下面先上代码 import ja…

Neo4j:Cypher –属性值只能是原始类型或其数组

本周初&#xff0c;当我尝试在我认为要共享的节点上创建数组属性时&#xff0c;遇到了一个有趣的Cypher错误消息。 这是我写的Cypher查询&#xff1a; CREATE (:Person {id: [1, "mark", 2.0]})导致此错误&#xff1a; Neo.ClientError.Statement.TypeError Prope…

通信工程制图期末考试大纲

通信工程建设的三个阶段 初步设计、技术设计、施工图设计 通信工程建设的参与方 1、建设单位&#xff1a;是建设工程的投资人&#xff0c;也称“业主"。 2、勘察单位&#xff1a;是指已通过建设行政主管部门的资质审查&#xff0c;从事工程测量、水文地质和岩土工程等工…

锁相环锁相原理简洁版

锁相环锁相原理 1.没有参考信号输入的时候&#xff0c;环路滤波器的输出为一个固定值&#xff0c;这是的VCO按照其固定的频率进行震荡 2.当有参考信号输入时&#xff0c;Ur和Uv同时加到鉴相器来鉴相&#xff0c;如果鉴相器fr和fv差别不大的话&#xff0c;这两个电压做差&#…

古诺模型_再见了古诺。 你好Drools工作台。

古诺模型Drools 6.0发生了许多变化。 随着功能和功能的更改&#xff0c;我们对Guvnor github存储库进行了重组&#xff0c;以更好地反映我们的新架构。 历史上&#xff0c;Guvnor一直是Drools的Web应用程序。 它由Drools专用的编辑器&#xff0c;后端存储库和简化的资产管理系统…

八千字复习一下天线与电磁波

1. 空间坐标系 空间直角坐标系&#xff08;常用&#xff09;极坐标系平面直角坐标系距离矢量就是空间向量坐标单位矢量就是给距离矢量xyz底下分别除以模长梯度就是xyz求偏导&#xff0c;记得写 ex⃗\vec{e_{x}}ex​​/ey⃗\vec{e_{y}}ey​​/ez⃗\vec{e_{z}}ez​​,最后方程左…

Apache Fluo:填充Google搜索索引的Percolator的实现

Apache Fluo是Apache Accumulo [3]的Percolator [2]&#xff08;填充Google的搜索索引&#xff09;的开源实现 。 使用Fluo&#xff0c;用户可以将新数据连续地合并到大型现有数据集中&#xff0c;而无需重新处理所有数据。 与批处理和流传输框架不同&#xff0c;Fluo提供了低得…

最通俗的语言讲解卷积码、码树图、状态图以及维特比译码

什么是卷积码&#xff1f; 卷积码是由伊利亚斯发明的一种非分组码&#xff0c;它更加倾向于纠错&#xff0c;对于实际的性能优于分组码&#xff0c;运算较为简单。 将卷积码记为(n,k,N),码率定义为k/n n是n个比特 k是k个信息位 N是N个信息段 卷积码编码器 组成&#xff1a…

通信系统的同步技术归纳

载波同步&#xff1a;在相干解调时&#xff0c;接收端的解调器要产生一个与接收到的载波同频同相的相干载波位同步&#xff1a;接收端产生一个与接收信号符号速率相同&#xff0c;相位与最佳判决时刻一致的定时脉冲序列信号群同步&#xff1a;群同步是指在接收端产生与“字、句…

c语言 在txt文件中搜索关键词_网络推广外包—网络推广外包如何在搜索引擎中体现关键词优化效果...

在当下的互联网时代中&#xff0c;没有企业愿意远离这种流量获取快、用户需求大、宣传推广能力见效快的搜索引擎&#xff0c;况且通过互联网的帮助下&#xff0c;企业网站能够通过搜索引擎进行关键词优化后获取更多的转化率&#xff0c;增加企业交易额度的提升&#xff0c;谁又…

Spring JPA数据+Hibernate+ MySQL + Maven

在Spring MVC的帮助下开发Web应用程序意味着要创建几个逻辑架构层。 层之一是DAO&#xff08;存储库&#xff09;层。 它负责与数据库进行通信。 如果您至少开发了DAO层一次&#xff0c;则应该知道它涉及许多样板代码。 Spring Data本身就是与DAO相关的日常工作的一部分。 在帖…