当副本集在本地 IP 地址上相互连接时,连接到远程 MongoDB 副本集

Sco*_*ott 3 mongodb mongodb-java gmongo

我们在本地网络接口(即192.168.1.x)上设置了一个mongo副本集。副本集成员是唯一知道此接口的成员。这些实例也位于可从我们的网络内部 (10.xxx) 寻址的外部接口上。当尝试仅使用 Java 驱动程序[2.10.1](通过gMongo 包装器)连接到“主节点”时,我们遇到了一个问题,即由于应用程序无法确定其他副本节点而无法建立连接。即使我提供服务器列表中的所有外部接口,也会发生这种情况。

我还需要能够设置从我的计算机到副本集的 SSH 隧道。我再次遇到了同样的问题,因为副本集提供了不适用于我的主机名和 IP 地址。

当副本仅通过本地 IP 地址相互了解时,如何连接到副本集?

以下是代码示例以及由此产生的错误。下面的示例假设已设置从本地主机到远程服务器的隧道。

@Grab(group='com.gmongo', module='gmongo', version='1.1')

import com.gmongo.*
import com.mongodb.*

def hosts= [
        [host:'127.0.0.1', port:29017],
        //[host:'127.0.0.1', port:29018],  //have tried with and without the others commented
        //[host:'127.0.0.1', port:29019],
        ]

List<ServerAddress> addrs = hosts.collect {it.port?new ServerAddress(it.host, it.port):new ServerAddress(it.host)}
MongoClientOptions clientOptions = new MongoClientOptions.Builder().build()
def mongo = new GMongoClient(addrs, clientOptions)
def db = mongo.getDB("mydb")

def result = db.tickets.findOne([:])

println result
Run Code Online (Sandbox Code Playgroud)

结果是这样的:

WARNING: couldn't resolve host [mongo03:27017]
May 16, 2013 10:54:59 AM com.mongodb.ReplicaSetStatus$UpdatableReplicaSetNode _addIfNotHere

WARNING: couldn't resolve host [mongo03:27017]
May 16, 2013 10:55:01 AM com.mongodb.ReplicaSetStatus$UpdatableReplicaSetNode findNode

WARNING: couldn't resolve host [mongo02:27017]
May 16, 2013 10:55:01 AM com.mongodb.ReplicaSetStatus$UpdatableReplicaSetNode _addIfNotHere

WARNING: couldn't resolve host [mongo02:27017]
May 16, 2013 10:55:01 AM com.mongodb.ReplicaSetStatus$UpdatableReplicaSetNode findNode
com.mongodb.MongoException: can't find a master

    at com.mongodb.DBTCPConnector.checkMaster(DBTCPConnector.java:518)

WARNING: Server seen down: /192.168.1.11:27017 - java.io.IOException - message: couldn't connect to [/192.168.1.11:27017] bc:java.net.SocketTimeoutException: connect timed out
Run Code Online (Sandbox Code Playgroud)

我不确定为什么它尝试根据服务器的本地配置而不是我提供的服务器列表进行解析。

fri*_*mer 5

根据我的经验,当副本集具有客户端和服务器都可以解析的 DNS 名称时,副本集效果最佳。

我使用了 pymongo 和 php MongoClient,如果客户端计算机使用副本集的 IP 地址,但副本集是使用 DNS 名称设置的,则客户端将无法连接(可能是因为当询问副本集哪个节点是主副本集可能会返回 DNS 名称)。

如果我使用 DNS 名称(我只是修改客户端上的主机文件),那么连接不会失败。

来自副本集的文档:

副本集的每个成员都必须可通过可解析的 DNS 或主机名进行访问

希望这可以帮助您调试问题。