Nota :Assicurati di controllare la risposta fornito da arcseldon per un equivalente facile da usare.
Puoi usare l'output di rs.status()
. Se il secondario è sincronizzato e non è stato creato con slaveDelay
opzione quindi optime
e optimeDate
di secondario dovrebbe essere uguale o vicino (se ci sono operazioni in corso) a quelli di primario. In tal caso stateStr
dovrebbe essere uguale a SECONDARY
. Quindi, se il secondario è sincronizzato, dovresti vedere un output simile a questo (un membro è stato rimosso dall'output per chiarezza):
{
"set" : "rs0",
"date" : ISODate("2013-11-08T14:58:49Z"),
"myState" : 1,
"members" : [
{
"_id" : 0,
"name" : "hostname:27001",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 155,
"optime" : Timestamp(1383915748, 1),
"optimeDate" : ISODate("2013-11-08T13:02:28Z"),
"self" : true
},
{
"_id" : 2,
"name" : "hostname:27003",
"health" : 0,
"state" : 8,
"stateStr" : "SECONDARY",
"uptime" : 0,
"optime" : Timestamp(1383915748, 1),
"optimeDate" : ISODate("2013-11-08T13:02:28Z"),
"lastHeartbeat" : ISODate("2013-11-08T14:58:48Z"),
"lastHeartbeatRecv" : ISODate("2013-11-08T14:58:42Z"),
"pingMs" : 0,
"syncingTo" : "hostname:27001"
}
],
"ok" : 1
}
Qui hai l'output di rs.status()
per lo stesso set di repliche se uno dei secondari non è sincronizzato. Prima di tutto vedrai che optime
e optimeDate
per hostname:27003
è diverso da primary, stateStr è impostato su RECOVERING
e c'è lastHeartbeatMessage
appropriato .
{
"set" : "rs0",
"date" : ISODate("2013-11-08T15:01:34Z"),
"myState" : 1,
"members" : [
{
"_id" : 0,
"name" : "hostname:27001",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 320,
"optime" : Timestamp(1383922858, 767),
"optimeDate" : ISODate("2013-11-08T15:00:58Z"),
"self" : true
},
{
"_id" : 2,
"name" : "hostname:27003",
"health" : 1,
"state" : 3,
"stateStr" : "RECOVERING",
"uptime" : 14,
"optime" : Timestamp(1383915748, 1),
"optimeDate" : ISODate("2013-11-08T13:02:28Z"),
"lastHeartbeat" : ISODate("2013-11-08T15:01:34Z"),
"lastHeartbeatRecv" : ISODate("2013-11-08T15:01:34Z"),
"pingMs" : 0,
"lastHeartbeatMessage" : "still syncing, not yet to minValid optime 527cfc90:19c4",
"syncingTo" : "hostname:27001"
}
],
"ok" : 1
}
Se il secondario è stato creato con slaveDelay
quindi optime
e optimeDate
può essere diverso ma stateStr
e lastHeartbeatMessage
indicherà se c'è qualche ritardo.