Java-клиент Mongodb не работает, когда узел основного сервера изменяется в репликационном наборе

2

Проблема: MongoDB записывает ошибку с ошибкой -

Вышло время после 30000 мс в ожидании сервера, который соответствует PrimaryServerSelector. Клиентский вид состояния кластера: {type = REPLICA_SET, servers = [{address = intdb01: 27017, type = REPLICA_SET_SECONDARY, roundTripTime = 0,7 мс, состояние = CONNECTED}]

Это происходит, когда первичный переключился с intdb01 на intdb02. Похоже, что клиентский драйвер все еще ищет, чтобы intdb01 был основным узлом.

Наши настройки

У нас есть 3 узла mongoDb в replicaSet, называемом rs0. Когда мы подключаемся к нему с помощью Java, мы даем все 3 сервера в строке подключения следующим образом: mongodb://intdb01: 27017, intdb02: 27017, intdb03: 27017/? ReplicaSet = rs0

db.version → 3.0.4

Версия драйвера Java: mongodb-driver-3.0.4.jar, mongodb-driver-core-3.0.4.jar

Код подключения клиента:

if( mongoClient == null) {
    MongoClientURI mcu = new MongoClientURI(mongoConnect);
    mongoClient = new MongoClient(mcu);
}

mongoConnect содержит строку соединения, показанную выше.

Информация о статусе Mongo Replicaset

> rs.status()
{
  "set" : "rs0",
  "date" : ISODate("2016-07-19T21:14:03.001Z"),
  "myState" : 1,
  "members" : [{
        "_id" : 0,
        "name" : "intdb01",
        "health" : 1,
        "state" : 2,
        "stateStr" : "SECONDARY",
        "uptime" : 439786,
        "optime" : Timestamp(1468521291, 5),
        "optimeDate" : ISODate("2016-07-14T18:34:51Z"),
        "lastHeartbeat" : ISODate("2016-07-19T21:14:01.877Z"),
        "lastHeartbeatRecv" : ISODate("2016-07-19T21:14:01.611Z"),
        "pingMs" : 0,
        "configVersion" : 4
    },
    {
        "_id" : 1,
        "name" : "intdb02:27017",
        "health" : 1,
        "state" : 1,
        "stateStr" : "PRIMARY",
        "uptime" : 2948844,
        "optime" : Timestamp(1468521291, 5),
        "optimeDate" : ISODate("2016-07-14T18:34:51Z"),
        "electionTime" : Timestamp(1468523057, 1),
        "electionDate" : ISODate("2016-07-14T19:04:17Z"),
        "configVersion" : 4,
        "self" : true
    },
    {
        "_id" : 2,
        "name" : "intdb03:27017",
        "health" : 1,
        "state" : 2,
        "stateStr" : "SECONDARY",
        "uptime" : 439779,
        "optime" : Timestamp(1468521291, 5),
        "optimeDate" : ISODate("2016-07-14T18:34:51Z"),
        "lastHeartbeat" : ISODate("2016-07-19T21:14:01.294Z"),
        "lastHeartbeatRecv" : ISODate("2016-07-19T21:14:01.294Z"),
        "pingMs" : 0,
        "configVersion" : 4
    }
  ],
  "ok" : 1
}

Я проверил и перепроверял код/​​конфиг с документацией, но не могу найти, что не так. Мы можем имитировать это, спустив основной. Второе занятие, но приложение записывает начало сбоя. :-(

Любые указатели/подсказки очень ценятся!

Добавление стека trace-

Caused by: com.mongodb.MongoTimeoutException: Timed out after 30000 ms while waiting for a server that matches PrimaryServerSelector. Client view of cluster state is {type=REPLICA_SET, servers=[{address=intdb01:27017, type=REPLICA_SET_SECONDARY, roundTripTime=0.7 ms, state=CONNECTED}]
at com.mongodb.connection.BaseCluster.createTimeoutException(BaseCluster.java:370)
at com.mongodb.connection.BaseCluster.selectServer(BaseCluster.java:101)
at com.mongodb.binding.ClusterBinding$ClusterBindingConnectionSource.<init>(ClusterBinding.java:75)
at com.mongodb.binding.ClusterBinding$ClusterBindingConnectionSource.<init>(ClusterBinding.java:71)
at com.mongodb.binding.ClusterBinding.getWriteConnectionSource(ClusterBinding.java:68)
at com.mongodb.operation.OperationHelper.withConnection(OperationHelper.java:175)
at com.mongodb.operation.MixedBulkWriteOperation.execute(MixedBulkWriteOperation.java:141)
at com.mongodb.operation.MixedBulkWriteOperation.execute(MixedBulkWriteOperation.java:72)
at com.mongodb.Mongo.execute(Mongo.java:747)
at com.mongodb.Mongo$2.execute(Mongo.java:730)
at com.mongodb.MongoCollectionImpl.executeSingleWriteRequest(MongoCollectionImpl.java:482)
at com.mongodb.MongoCollectionImpl.update(MongoCollectionImpl.java:474)
at com.mongodb.MongoCollectionImpl.updateOne(MongoCollectionImpl.java:325)
at com.grid.core.persistence.mongodb.dao.GridEventDao.save(GridEventDao.java:69)
... 6 more
2016-07-19 17:05:01,882 [pool-2-thread-2] INFO   org.mongodb.driver.cluster - No server chosen by PrimaryServerSelector from cluster description ClusterDescription{type=REPLICA_SET, connectionMode=SINGLE, all=[ServerDescription{address=intdb01:27017, type=REPLICA_SET_SECONDARY, state=CONNECTED, ok=true, version=ServerVersion{versionList=[3, 0, 4]}, minWireVersion=0, maxWireVersion=3, electionId=null, maxDocumentSize=16777216, roundTripTimeNanos=724681, setName='rs0', canonicalAddress=intdb01:27017, hosts=[intdb01:27017, intdb02:27017], passives=[intdb03:27017], arbiters=[], primary='intdb02:27017', tagSet=TagSet{[]}}]}. Waiting for 30000 ms before timing out

Я пытаюсь выяснить, является ли это ошибкой или конфигурацией кодирования. Последнее информационное сообщение в трассировке стека говорит, что connectionMode равно SINGLE. У вас есть подозрение, что он вызывает эту проблему, но я не могу найти информацию об этом на сайте документации разработчика.

  • 0
    Если вы собираетесь отказаться от голосования, будьте достаточно мужественны, чтобы выразить свою обеспокоенность, чтобы она стала лучше. То же самое относится и к человеку, голосующему за закрытие.
  • 0
    Можете ли вы предоставить полную трассировку стека, пожалуйста.
Показать ещё 3 комментария
Теги:
replicaset
mongodb-replica-set

1 ответ

0

Все адреса сервера должны появиться в сообщении об ошибке. Например, попробуйте сделать это с тремя произвольными именами хостов, которые не будут разрешены:

com.mongodb.MongoTimeoutException: Timed out after 30000 ms while waiting for a server that matches PrimaryServerSelector. Client view of cluster state is {type=REPLICA_SET, servers=[{address=xxx:27117, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketException: xxx}, caused by {java.net.UnknownHostException: xxx}}, {address=xxx:27118, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketException: xxx}, caused by {java.net.UnknownHostException: xxx}}, {address=xxx:27119, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketException: xxx}, caused by {java.net.UnknownHostException: xxx}}]
    at com.mongodb.connection.BaseCluster.createTimeoutException(BaseCluster.java:370)
    at com.mongodb.connection.BaseCluster.selectServer(BaseCluster.java:101)
    at com.mongodb.binding.ClusterBinding$ClusterBindingConnectionSource.(ClusterBinding.java:75)
    at com.mongodb.binding.ClusterBinding$ClusterBindingConnectionSource.(ClusterBinding.java:71)
    at com.mongodb.binding.ClusterBinding.getWriteConnectionSource(ClusterBinding.java:68)
    at com.mongodb.operation.OperationHelper.withConnection(OperationHelper.java:175)
    at com.mongodb.operation.BaseWriteOperation.execute(BaseWriteOperation.java:106)
    at com.mongodb.operation.BaseWriteOperation.execute(BaseWriteOperation.java:58)
    at com.mongodb.Mongo.execute(Mongo.java:747)
    at com.mongodb.Mongo$2.execute(Mongo.java:730)
    at com.mongodb.DBCollection.executeWriteOperation(DBCollection.java:327)
    at com.mongodb.DBCollection.insert(DBCollection.java:323)
    at com.mongodb.DBCollection.insert(DBCollection.java:314)
    at com.mongodb.DBCollection.insert(DBCollection.java:284)
    at com.mongodb.DBCollection.insert(DBCollection.java:250)
    at com.mongodb.DBCollection.insert(DBCollection.java:187)
    at InsertTest2.main(InsertTest2.java:26)

Обратите внимание, как появляются все 3 адреса сервера. Я бы посоветовал вам создать простую тестовую программу, подобную этой, и проверить, а затем отложить назад. Также убедитесь, что имена хостов правильно разрешены, вы также можете попробовать IP-адреса.

  • 0
    Я попробую. - создайте простой тест и идите оттуда. Это не разрешение Host / IP, так как я могу подключаться независимо ко всем, только когда вторичное становится первичным. Я подозреваю что-то в том, как у меня есть строка подключения. Я буду играть и обновлять, если я добьюсь прогресса. Последний вариант - загрузить исходный код, если я смогу найти его для org.mongodb.driver.cluster.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню