草庐IT

node.js - 来自 NodeJS 的 MongoDB 副本连接

coder 2023-10-30 原文

我的 NodeJS 客户端能够根据要求连接到 MongoDB 主服务器并与之交互。

我使用下面的代码构建一个服务器对象

var dbServer = new Server(
    host,  // primary server IP address
    port,  
    { 
        auto_reconnect: true,
        poolSize: poolSize   
    });

和以下创建数据库对象的代码:

var db = new Db(
    'MyDB',
    dbServer,
    { w: 1 }
);

我的印象是,当主 Node 出现故障时,客户端会自动发现它现在需要与其中一个辅助 Node 通信,该辅助 Node 将被选为主要 Node 。

但是当我手动终止主服务器时,其中一个辅助服务器确实成为主服务器(从它的 mongo shell 可以观察到它现在响应 mongo shell 命令的事实),但客户端不会自动跟它说话。如何配置 NodeJS 服务器自动切换到辅助服务器?

我需要在某处指定所有 3 个服务器地址吗?但这似乎不是一个好的解决方案,因为一旦主服务器重新联机,它的 IP 地址将与原来的不同。

我觉得我缺少一些非常基本的东西,请赐教:)

谢谢你, 加里

最佳答案

好吧,你的理解只是其中的一部分,但还有一些问题。在连接中分配多个单一服务器的一般前提是,如果该服务器地址在连接时不可用,则将从“种子列表”中选择其他内容以建立连接。这消除了单点故障,例如此时“主要”不可用。

如果这是一个“副本集”,那么驱动程序将在连接后发现成员,然后在该成员被选出时“自动”切换到新的“主”。所以这确实需要你的“副本集”实际上能够选择一个新的“主”来切换连接。此外,这不是“即时的”,因此在提升新的“主要”并能够接受操作之前可能会有延迟。

您的“auto_reconnect”设置也没有按照您认为的那样进行。所有这一切管理的是,如果发生连接“错误”,驱动程序将“自动”重试连接而不抛出异常。您可能真正想做的是自己处理这个问题,因为您最终可能会无限重试无法建立的连接。好的代码会考虑到这一点,并通过一些合理的处理和日志记录来管理“重新连接”尝试。

您关于 IP 地址的最后一点通常是通过使用解析为 IP 地址的主机名来解决的,其中这些“主机名”永远不会改变,无论它们解析为什么。这对驱动程序和“副本集”本身同样重要。实际上,如果服务器成员正在通过更改的 IP 地址寻找另一个成员,那么他们不知道要寻找什么。

因此驱动程序将“故障转移”或以其他方式选择一个新的可用“主要”,但仅在服务器之间也可以相互通信的相同容差范围内。您应该为您的连接设置种子,因为您无法保证连接时哪个 Node 是“主要” Node 。最后,如果 IP 地址可能发生变化,您应该使用主机名而不是 IP 地址。

驱动程序将“ self 发现”,但同样它只使用副本集可用的配置来这样做。如果该配置对副本集无效,那么它对驱动程序也无效。

例子:

MongoClient.connect("mongodb://member1,member2,member3/database", function(err,db) {

})

或者用 Server 对象数组代替。

关于node.js - 来自 NodeJS 的 MongoDB 副本连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24239253/

有关node.js - 来自 NodeJS 的 MongoDB 副本连接的更多相关文章

  1. ruby - 续集在添加关联时访问many_to_many连接表 - 2

    我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以

  2. ruby - 无法在 60 秒内获得稳定的 Firefox 连接 (127.0.0.1 :7055) - 2

    我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类

  3. ruby - 我的 Ruby IRC 机器人没有连接到 IRC 服务器。我究竟做错了什么? - 2

    require"socket"server="irc.rizon.net"port="6667"nick="RubyIRCBot"channel="#0x40"s=TCPSocket.open(server,port)s.print("USERTesting",0)s.print("NICK#{nick}",0)s.print("JOIN#{channel}",0)这个IRC机器人没有连接到IRC服务器,我做错了什么? 最佳答案 失败并显示此消息::irc.shakeababy.net461*USER:Notenoughparame

  4. ruby-on-rails - 连接字符串时如何在 <%=%> block 内输出 html_safe? - 2

    考虑一下:现在这些情况:#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2#output:http://domain.com/?foo=1&bar=2我需要用其他字符串输出URL。我如何保证&符号不会被转义?由于我无法控制的原因,我无法发送&。求助!把我的头发拉到这里:\编辑:为了澄清,我实际上有一个像这样的数组:@images=[{:id=>"fooid",:url=>"http://

  5. ruby - 可以正常中断的来自 Rake 的长时间运行的 shell 命令? - 2

    在几个项目中,我希望有一个类似rakeserver的rake任务,它将通过任何需要的方式开始为该应用程序提供服务。这是一个示例:task:serverdo%x{bundleexecrackup-p1234}end这行得通,但是当我准备停止它时,按Ctrl+c并没有正常关闭;它中断了Rake任务本身,它说rakeaborted!并给出堆栈跟踪。在某些情况下,我必须执行Ctrl+c两次。我可能可以用Signal.trap写一些东西来更优雅地中断它。有没有更简单的方法? 最佳答案 trap('SIGINT'){puts"Yourmessa

  6. ruby - Faye WebSocket,关闭处理程序被触发后重新连接到套接字 - 2

    我有一个super简单的脚本,它几乎包含了FayeWebSocketGitHub页面上用于处理关闭连接的内容:ws=Faye::WebSocket::Client.new(url,nil,:headers=>headers)ws.on:opendo|event|p[:open]#sendpingcommand#sendtestcommand#ws.send({command:'test'}.to_json)endws.on:messagedo|event|#hereistheentrypointfordatacomingfromtheserver.pJSON.parse(event.d

  7. ruby - ruby 中的同一个程序如何接受来自用户的输入以及命令行参数 - 2

    我的ruby​​脚本从命令行参数获取某些输入。它检查是否缺少任何命令行参数,然后提示用户输入。但是我无法使用gets从用户那里获得输入。示例代码:test.rbname=""ARGV.eachdo|a|ifa.include?('-n')name=aputs"Argument:#{a}"endendifname==""puts"entername:"name=getsputsnameend运行脚本:rubytest.rbraghav-k错误结果:test.rb:6:in`gets':Nosuchfileordirectory-raghav-k(Errno::ENOENT)fromtes

  8. ruby-on-rails - Rails 3,在RAILS_ROOT上方显示来自本地文件系统的jpg图片 - 2

    我正在尝试找出一种方法来显示来自不在RAILS_ROOT下(在RedHat或Ubuntu环境中)的已安装文件系统的图像。我不想使用符号链接(symboliclink),因为这个应用程序实际上是通过Tomcat部署的,而当我关闭Tomcat时,Tomcat会尝试跟随符号链接(symboliclink)并删除挂载中的所有图像。由于这些文件的数量和大小,将图像放在public/images下也不是一种选择。我查看了send_file,但它只会显示一张图片。我需要在一个格式良好的页面中显示6个请求的图像。由于膨胀,我宁愿不使用Base64编码,但我不知道如何将图像数据与呈现的页面一起传递下去。

  9. ruby-on-rails - 什么会导致与 APNS 的连接间歇性断开连接? - 2

    我有一个ruby​​脚本可以打开与Apple推送服务器的连接并发送所有待处理的通知。我看不出任何原因,但当Apple断开我的脚本时,我遇到了管道损坏错误。我已经编写了我的脚本来适应这种情况,但我宁愿只是找出它发生的原因,这样我就可以在第一时间避免它。它不会始终根据特定通知断开连接。它不会以特定的字节传输大小断开连接。一切似乎都是零星的。您可以在单个连接上发送的数据传输或有效负载计数是否有某些限制?看到人们的解决方案始终保持一个连接打开,我认为这不是问题所在。我看到连接在3次通知后断开,我看到它在14次通知后断开。我从未见过它能超过14点。有没有人遇到过这种类型的问题?如何处理?

  10. ruby - 如何断开现有的 ruby​​ 续集与数据库的连接? - 2

    我的意思是之前建立的那个DB=Sequel.sqlite('my_blog.db')或DB=Sequel.connect('postgres://user:password@localhost/my_db')或DB=Sequel.postgres('my_db',:user=>'user',:password=>'password',:host=>'localhost')等等。Sequel::Database类没有名为“disconnect”的公共(public)实例方法,尽管它有一个“connect”。也许有人已经遇到过这个问题。我将不胜感激。 最佳答案

随机推荐