Each member of a replica set has a state.副本集的每个成员都有一个状态。
| 0 | STARTUP | mongod parses the replica set configuration document while in STARTUP. |
| 1 | PRIMARY | |
| 2 | SECONDARY | |
| 3 | RECOVERING | |
| 5 | STARTUP2 | |
| 6 | UNKNOWN | |
| 7 | ARBITER | |
| 8 | DOWN | |
| 9 | ROLLBACK |
Starting in version 4.2, MongoDB kills all in-progress user operations when a member enters the |
| 10 | REMOVED |
States
Core States
PRIMARY- Members in
PRIMARYstate accept write operations. A replica set has at most one primary at a time. [1] ASECONDARYmember becomes primary after an election. Members in thePRIMARYstate are eligible to vote.
SECONDARY- Members in
SECONDARYstate replicate the primary's data set and can be configured to accept read operations. Secondaries are eligible to vote in elections, and may be elected to thePRIMARYstate if the primary becomes unavailable.
ARBITER- Members in
ARBITERstate do not replicate data or accept write operations. They are eligible to vote, and exist solely to break a tie during elections. Replica sets should only have a member in theARBITERstate if the set would otherwise have an even number of voting members, and could suffer from tied elections. There should only be at most one arbiter configured in any replica set. For considerations when using an arbiter, see Replica Set Arbiter.
See Replica Set Members for more information on core states.
Other States
STARTUP- Each member of a replica set starts up in
STARTUPstate.mongodthen loads that member's replica set configuration, and transitions the member's state toSTARTUP2orARBITER. Members inSTARTUPare not eligible to vote, as they are not yet a recognized member of any replica set.
STARTUP2Changed in version 5.0.在版本5.0中的更改。Each data-bearing member of a replica set enters the
STARTUP2state as soon asmongodfinishes loading that member's configuration.The member then decides whether or not to undertake an initial sync. If a member begins an initial sync, the member remains in
STARTUP2until all data is copied and all indexes are built. Afterwards, the member transitions toRECOVERING.Newly-added members in
STARTUP2are not eligible to vote and cannot be elected during the initial sync process. Prior to MongoDB 5.0, members inSTARTUP2were eligible to vote.
RECOVERINGA member of a replica set enters
RECOVERINGstate when it is not ready to accept reads. TheRECOVERINGstate can occur during normal operation, and doesn't necessarily reflect an error condition. Members in theRECOVERINGstate are eligible to vote in elections, but are not eligible to enter thePRIMARYstate.A member transitions from
RECOVERINGtoSECONDARYafter replicating enough data to guarantee a consistent view of the data for client reads. The only difference betweenRECOVERINGandSECONDARYstates is thatRECOVERINGprohibits client reads andSECONDARYpermits them.SECONDARYstate does not guarantee anything about the staleness of the data with respect to the primary.Due to overload, a secondary may fall far enough behind the other members of the replica set such that it may need to resync with the rest of the set. When this happens, the member enters the
RECOVERINGstate and requires manual intervention.
ROLLBACKWhenever the replica set replaces a primary in an election, the old primary may contain documents that did not replicate to the secondary members. In this case, the old primary member reverts those writes. During rollback, the member will have
ROLLBACKstate. Members in theROLLBACKstate are eligible to vote in elections.Starting in version 4.2, MongoDB kills all in-progress user operations when a member enters the
ROLLBACKstate.
Error States
Members in any error state can't vote.
UNKNOWN- Members that have never communicated status information to the replica set are in the
UNKNOWNstate.
DOWN- Members that lose their connection to the replica set are seen as
DOWNby the remaining members of the set.
REMOVED- Members that are removed from the replica set enter the
REMOVEDstate. When members enter theREMOVEDstate, the logs will mark this event with areplSet REMOVEDmessage entry.
| [1] | In some circumstances, two nodes in a replica set may transiently believe that they are the primary, but at most, one of them will be able to complete writes with { w: "majority" } write concern. The node that can complete { w: "majority" } writes is the current primary, and the other node is a former primary that has not yet recognized its demotion, typically due to a network partition. When this occurs, clients that connect to the former primary may observe stale data despite having requested read preference primary, and new writes to the former primary will eventually roll back. |