Mongo中的SocketException

时间:2013-09-09 23:04:29

标签: mongodb scala casbah

我只是在Mongo(prod环境)中设置了一个副本集。我现在得到了很多例外情况,如下面所示(剪辑)。

我进入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)

1 个答案:

答案 0 :(得分:0)

通常,在副本集中从以下某个位置发生连接超时
1)所有成员都无法相互沟通 2)程序正在连接到副本以进行更新,并且由于过载或第1个而无法将其发送到主副本 3)所有的复制品都没有同步,而且一个人太落后了 4)由于某种原因,领导人选举正在进行但尚未完成
请检查您的副本设置是否一致,并且所有节点都在主节点上发出rs.status(),同样如前面建议的那样检查主日志以获取更多信息。