【问题标题】:SocketException in MongoMongo中的SocketException
【发布时间】:2013-09-13 13:00:33
【问题描述】:

我刚刚在 Mongo(产品环境)中设置了一个副本集。我现在遇到很多异常,如下所示(已剪辑)。

我进入 mongo 并在我的主 mongo 节点上运行了一个 serverStatus 命令,并且只有大约 300 个连接,所以它几乎无法正常工作。

以下是我的服务器代码中的连接选项设置:

auto_connect_retry = false    
connections_per_host = 10     
threads_multiplier = 10       
max_wait_time = 120000       
connect_timeout = 10000       
socket_timeout = 0           

我的配置有误吗?

Sep 9, 2013 8:31:26 PM com.mongodb.DBPortPool gotError
WARNING: emptying DBPortPool to /10.0.8.10:27017 b/c of error
java.net.SocketException: Connection timed out
    at java.net.SocketInputStream.socketRead0(Native Method)
    at java.net.SocketInputStream.read(SocketInputStream.java:146)
    at java.io.BufferedInputStream.fill(BufferedInputStream.java:235)
    at java.io.BufferedInputStream.read1(BufferedInputStream.java:275)
    at java.io.BufferedInputStream.read(BufferedInputStream.java:334)
    at org.bson.io.Bits.readFully(Bits.java:46)
    at org.bson.io.Bits.readFully(Bits.java:33)
    at org.bson.io.Bits.readFully(Bits.java:28)
    at com.mongodb.Response.<init>(Response.java:40)
    at com.mongodb.DBPort.go(DBPort.java:142)
    at com.mongodb.DBPort.call(DBPort.java:92)
    at com.mongodb.DBTCPConnector.innerCall(DBTCPConnector.java:244)
    at com.mongodb.DBTCPConnector.call(DBTCPConnector.java:216)
    at com.mongodb.DBApiLayer$MyCollection.__find(DBApiLayer.java:288)
    at com.mongodb.DBApiLayer$MyCollection.__find(DBApiLayer.java:273)
    at com.mongodb.DBCollection.findOne(DBCollection.java:347)
    at com.mongodb.DBCollection.findOne(DBCollection.java:332)
    at com.mongodb.casbah.MongoCollectionBase$class.findOneByID(MongoCollection.scala:232)
    at com.mongodb.casbah.MongoCollection.findOneByID(MongoCollection.scala:866)
    at com.novus.salat.dao.SalatDAO.findOneById(SalatDAO.scala:353)
    at com.novus.salat.dao.ModelCompanion$class.findOneById(ModelCompanion.scala:173)

【问题讨论】:

  • 能否附上主节点的日志?
  • 另外,请通过显示相关代码或配置告诉我们您是如何连接副本集的。

标签: mongodb scala casbah


【解决方案1】:

通常连接超时发生在副本集中的以下任一情况
1)所有成员都无法相互交流
2) 一个程序正在连接到副本进行更新,但由于过载或第一次也无法将其发送到主副本
3)所有遗物不同步,一个落后太多
4) 由于某种原因,Leader 选举正在进行但未完成

请通过在主节点上发出 rs.status() 来检查您的 relica 集是否一致并且所有节点都在工作,同样如前所述,请检查主日志以获取更多信息

【讨论】:

    猜你喜欢
    • 2014-12-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多