我已将MongoDB数据库配置为单节点副本集。我可以通过api(写入数据)和shell来访问它:
rs0:PRIMARY> rs.status()
{
"set" : "rs0",
"date" : ISODate("2017-12-18T14:37:13.487Z"),
"myState" : 1,
"term" : NumberLong(1),
"heartbeatIntervalMillis" : NumberLong(2000),
"optimes" : {
"lastCommittedOpTime" : {
"ts" : Timestamp(1513607826, 1),
"t" : NumberLong(1)
},
"readConcernMajorityOpTime" : {
"ts" : Timestamp(1513607826, 1),
"t" : NumberLong(1)
},
"appliedOpTime" : {
"ts" : Timestamp(1513607826, 1),
"t" : NumberLong(1)
},
"durableOpTime" : {
"ts" : Timestamp(1513607826, 1),
"t" : NumberLong(1)
}
},
"members" : [
{
"_id" : 0,
"name" : "srvlx02:27017",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 14633,
"optime" : {
"ts" : Timestamp(1513607826, 1),
"t" : NumberLong(1)
},
"optimeDate" : ISODate("2017-12-18T14:37:06Z"),
"electionTime" : Timestamp(1513593354, 2),
"electionDate" : ISODate("2017-12-18T10:35:54Z"),
"configVersion" : 1,
"self" : true
}
],
"ok" : 1,
"operationTime" : Timestamp(1513607826, 1),
"$clusterTime" : {
"clusterTime" : Timestamp(1513607826, 1),
"signature" : {
"hash" : BinData(0,"AAAAAAAAAAAAAAAAAAAAAAAAAAA="),
"keyId" : NumberLong(0)
}
}
}
rs0:PRIMARY> rs.conf()
{
"_id" : "rs0",
"version" : 1,
"protocolVersion" : NumberLong(1),
"members" : [
{
"_id" : 0,
"host" : "srvlx02:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : {
},
"slaveDelay" : NumberLong(0),
"votes" : 1
}
],
"settings" : {
"chainingAllowed" : true,
"heartbeatIntervalMillis" : 2000,
"heartbeatTimeoutSecs" : 10,
"electionTimeoutMillis" : 10000,
"catchUpTimeoutMillis" : -1,
"catchUpTakeoverDelayMillis" : 30000,
"getLastErrorModes" : {
},
"getLastErrorDefaults" : {
"w" : 1,
"wtimeout" : 0
},
"replicaSetId" : ObjectId("5a379a0abe6cad70a6b66c7c")
}
}
rs0:PRIMARY>
但是,当我通过Compass连接到它时,它将拓扑显示为UNKNOWN,并且不允许修改/删除集合/数据库。
可能是什么问题?为什么Compass无法确定拓扑?是否支持单节点副本集特殊情况?
感谢您的任何提示!
MongoDB版本:3.6.0
MongoDB shell version v3.6.0
connecting to: mongodb://127.0.0.1:27017
MongoDB server version: 3.6.0
指南针版本:1.11.1社区版
答案 0 :(得分:2)
如果其他人也遇到相同的问题,我刚刚在MongoDB Jira上发现了关于同一问题的错误报告:https://jira.mongodb.org/browse/COMPASS-3264。
解决方案是将“ Replica Set Name”字段保留为空,这样就可以了:)
答案 1 :(得分:0)
我今天遇到了这个问题,并将其追溯到MongoDB服务器上的防火墙。我已经打开了副本集实例之一的端口,但不是全部。我认为您运行罗盘的计算机需要访问副本集中的所有实例。
答案 2 :(得分:0)
我今天遇到了这个问题,因为我的IP地址已经从最初添加到Atlas的IP白名单中的IP地址更改了。我必须在Atlas IP白名单设置中选择“允许从任何地方访问”选项,才能使指南针再次工作。
答案 3 :(得分:0)
我认为这是因为您的公共 IP 已更改,当您将 mongodb atlas 与指南针连接时,就会发生这种情况, enter image description here 尝试添加另一个 IP。