2

我正在运行 MongoDB ReplicaSets 的 Kubernetes 集群。

我已经很好地初始化了副本集,并且一切都彼此同步。

members" : [
            {
                    "_id" : 1,
                    "host" : "10.244.7.3:27017",
                    "arbiterOnly" : false,
                    "buildIndexes" : true,
                    "hidden" : false,
                    "priority" : 1,
                    "tags" : {

                    },
                    "slaveDelay" : 0,
                    "votes" : 1
            },
            {
                    "_id" : 2,
                    "host" : "10.244.6.4:27017",
                    "arbiterOnly" : false,
                    "buildIndexes" : true,
                    "hidden" : false,
                    "priority" : 1,
                    "tags" : {

                    },
                    "slaveDelay" : 0,
                    "votes" : 1
            },
            {
                    "_id" : 3,
                    "host" : "10.244.7.5:27017",
                    "arbiterOnly" : false,
                    "buildIndexes" : true,
                    "hidden" : false,
                    "priority" : 1,
                    "tags" : {

                    },
                    "slaveDelay" : 0,
                    "votes" : 1
            }
    ]

但是,当我尝试使用 pymongo 使用私有公开的 ip 地址(在 范围内172.20.x)进行连接时,运行查询会尝试使用 mongo 复制服务器提供的 ip 连接到副本集。

import pymongo                                                                                          
from pymongo import MongoClient                                                                         


mongo_uri = "mongodb://172.20.0.19:31892,172.20.0.80:31892,172.20.0.49:31892,172.20.0.147:31892/a-dev?replicaSet=rs0"

c = MongoClient(mongo_uri)
c['test_db'].tab.find_one()

# Returns a
*** pymongo.errors.ServerSelectionTimeoutError: 10.244.6.4:27017: timed out,10.244.7.5:27017: timed out,10.244.7.3:27017: timed out

这表明 pymongo 正在使用从副本集的配置提供的值,而不是使用我定义的 IP 地址。无论如何要禁用此默认行为?

4

0 回答 0