write_concern
– Tools for specifying write concern¶
Tools for working with write concerns.
- class pymongo.write_concern.WriteConcern(w: Optional[Union[int, str]] = None, wtimeout: Optional[int] = None, j: Optional[bool] = None, fsync: Optional[bool] = None)¶
- Parameters
w: (integer or string) Used with replication, write operations will block until they have been replicated to the specified number or tagged set of servers. w=<integer> always includes the replica set primary (e.g. w=3 means write to the primary and wait until replicated to two secondaries). w=0 disables acknowledgement of write operations and can not be used with other write concern options.
wtimeout: (integer) Used in conjunction with w. Specify a value in milliseconds to control how long to wait for write propagation to complete. If replication does not complete in the given timeframe, a timeout exception is raised.
j: If
True
block until write operations have been committed to the journal. Cannot be used in combination with fsync. Write operations will fail with an exception if this option is used when the server is running without journaling.fsync: If
True
and the server is running without journaling, blocks until the server has synced all data files to disk. If the server is running with journaling, this acts the same as the j option, blocking until write operations have been committed to the journal. Cannot be used in combination with j.
- property acknowledged: bool¶
If
True
write operations will wait for acknowledgement before returning.
- property document: Dict[str, Any]¶
The document representation of this write concern.
Note
WriteConcern
is immutable. Mutating the value ofdocument
does not mutate thisWriteConcern
.