当前位置: 首页 > 知识库问答 >
问题:

Mongo DB副本集配置问题

曹驰
2023-03-14

我知道我们需要有至少3个服务器的mongo副本集,但我试图配置mongo DB副本集只有两个服务器,如果我想添加一个aribter节点。请让我知道我可以在哪里添加仲裁器节点,以及如何使用那些(主-次-树)配置来配置副本集

共有1个答案

师赤岩
2023-03-14

第1步:启动三个mongod实例,如果所有实例都使用相同的服务器,请确保为每个mongod更改port和dbpath。如果使用不同的服务器,所有命令的端口都可以设置为27017。

mongod --replSet rs0 --port 27017 --bind_ip localhost,<hostname(s)|ip address(es)> --dbpath /srv/mongodb/rs0-0  --oplogSize 128

步骤2:使用上述方法启动3个实例后,连接到任一服务器上的mongo shell,并声明“cfg”变量。

cfg = {
  _id: "rs0",
  members: [
    {
     _id: 0,
     host: "<hostname1>:27017"
    },
    {
     _id: 1,
     host: "<hostname2>:27017"
    }
   ]
}

并运行下面的命令来配置副本集。注意:如果所有实例都使用相同的服务器,则将member_id:1的端口号更改为27018。

rs.initiate( cfg )
rs.addArb("hostname3:27017")

快乐编码!保持安全@家:)

 类似资料:
  • 我正在运行AWS EC2上设置的三个远程实例副本,并为我的IP打开了端口27017和ICMP上的安全组(防火墙)。 我的开发环境是Mac OS X上带有PHP 5.6.2的MAMP。当PHP测试文件中的新MongoClient时,我提供了一个连接字符串: mongodb://52.68.25.131:27017,52.68.29.231:27017,52.68.50.99:27017/?repli

  • 本文向大家介绍MongoDB的主从复制及副本集的replSet配置教程,包括了MongoDB的主从复制及副本集的replSet配置教程的使用技巧和注意事项,需要的朋友参考一下 复制 MongoDB的复制功能很重要,尤其是现在的存储引擎还不支持单击持久性。不仅可以用复制来应对故障切换,数据集成,还可以做读扩展,热备份或作为离线批处理的数据源。 1.主从复制 主从复制是MongoDB最常用的复制方式。

  • 本文向大家介绍CentOS 6.4创建Mongodb副本集,包括了CentOS 6.4创建Mongodb副本集的使用技巧和注意事项,需要的朋友参考一下 MongoDB是一个开源的non-SQL数据库引擎。 MongoDB是可扩展的,是标准关系数据库管理系统(RDBMS)的替代品。 副本集可以使在节点发生故障时还能提供对您的数据的访问。 安装MongoDB 1.确保在副本集的每个成员设置好hostn

  • 我们有一个mongodb副本集,其中包含两个实例(127.0.0.1:27017-主要,127.0.0.1:27018-次要)和一个仲裁器(127.0.0.1:27019)。当我使用rs.steppdown(60)从主实例中退出时,它应该成为辅助实例,辅助实例应该成为主实例,所有写操作都应该在辅助实例中发生(退出后的主实例)。但在卸任后,我遇到了一个异常“无法将数据写入传输连接:远程主机强制关闭了

  • 只读操作: 有没有办法有一个MongoDB副本集,但要使连接到的框上的MongoDB实例成为被查询的MongoDB? 我在AWS负载平衡器后面有三个EC2实例。 在每个EC2实例上运行MongoDB,它是副本集的一部分。 我在nodeJS上有expressendpoint,我连接到副本集,如下所示 我希望在MongoDB副本集的所有三个实例上均匀分布查询负载,而不是默认情况下将所有查询路由到定义了

  • 主程序的日志文件包含大量的getmore oplog查询-我猜主程序上的任何操作都会创建一个oplog查询。在我看来,这是太多的复制开销,但我没有任何关于MongoDB负载的经验,也没有任何关键数据。 由于安装程序将不得不容忍更多的生产负载,我的问题是,复制开销是否是预期的,即使是在次要服务器上,CPU负载增加这么高是否正常,还是我遗漏了什么?