replSetMaintenance
Definition
- replSetMaintenance
- The - replSetMaintenanceadmin command enables or disables the maintenance mode for a secondary member of a replica set.
Compatibility
This command is available in deployments hosted in the following environments:
- MongoDB Atlas: The fully managed service for MongoDB deployments in the cloud 
Important
This command is not supported in M0, M2, M5, M10+, and Flex clusters. For more information, see Unsupported Commands.
- MongoDB Enterprise: The subscription-based, self-managed version of MongoDB 
- MongoDB Community: The source-available, free-to-use, and self-managed version of MongoDB 
Syntax
The command has the following syntax:
db.runCommand(    {      replSetMaintenance: <boolean>    } ) 
Behavior
Consider the following behavior when running the
replSetMaintenance command:
- You cannot run the command on the Primary. 
- You must run the command against the - admindatabase.
- When enabled - replSetMaintenance: true, the member enters the- RECOVERINGstate. While the secondary is- RECOVERING:- The member is not accessible for read operations. 
- The member continues to sync its oplog from the Primary. 
 
- When a node receives a - replSetMaintenance: truerequest, it adds a maintenance mode task to a queue of tasks. If the queue of tasks was empty and now is not, the node will transition to- RECOVERINGstate and begin to reject read requests. When a node receives a- replSetMaintenance: falserequest, it removes a maintenance mode task from the queue (even if that task was initiated by a different client). If the request empties the maintenance mode task queue, the node will return to- SECONDARYstate.
- If you want to prevent a node from servicing reads, consider using Hidden Replica Set Members instead.