开发者社区> 问答> 正文

mongo集群经过ip映射后的连接问题

homolo 2019-06-10 15:50:00 198

现在有3台内网服务器启3节点mongo集群,
主节点: 10.222.0.1:27017,从节点1:10.222.0.2:27017,从节点2: 10.222.0.3:27017
集群搭建没有问题,节点初始化使用
rs.initiate({_id: “mongodata”, members: [{ _id: 1, host:"10.222.0.1:27017", priority: 100}, { _id: 2, host:"10.222.0.2:27017"}, { _id: 3, host:"10.222.0.3:27017"}]});

现在需要外网应用使用该集群,通过防火墙给3条内网ip分别映射ip地址:
114.114.114.111:27017, 114.114.114.112:27017,114.114.114.113:27017

然后使用外网方式 mongoshell连接: mongo –host 114.114.114.111:27017, 114.114.114.112:27017,114.114.114.113:27017 没有问题,
可是我把host 114.114.114.111:27017, 114.114.114.112:27017,114.114.114.113:27017 配置到应用的数据库驱动(tomcat数据源)里,就会出现问题:
timeout 10.222.0.1:27017,10.222.0.2:27017, 10.222.0.3:27017 ,奇怪为什么应用去连接映射出来的地址为什么会解析到要用到这三个内网地址,肯定是无法连接的

应用服务中间件 网络安全 数据库
分享到
取消 提交回答
全部回答(1)
  • 养狐狸的猫
    2019-09-27 20:35:22

    可能是Mongodb数据库的有的文档的字段和Class的字段无法匹配,可以在字段上加上BsonIgnoreIfNullAttribute属性

    答案来源于网络

    0 0
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

推荐文章
相似问题
推荐课程