如何在Python中正确使用MongoDB事务

MongoDB事务仅支持副本集或分片集群,单节点不支持;需显式传入session参数,超时60秒不可配置;writeConcern和readConcern需合理设置以保障一致性。事务只在副本集或分片集群上可用单节点 MongoDB 实例不支持事务,调用 start_transaction() 会直接报错 OperationFailure: Transactions are not supported on this deployment。这是最常卡住新手的第一步。本地开发时,别用 mongod --dbpath 启动单机版,改用 mongod --replSet rs0 并执行 rs.initiate()Docker 中快速起副本集:用官方镜像的 docker-compose.yml 示例,确保包含 replication.replSetName 配置云服务(如 MongoDB Atlas)默认开副本集,但免费共享层(M0)仍不支持事务------得升到 M10 或更高session 必须显式传入每个操作MongoDB Python 驱动不会自动把操作绑定到当前事务上下文,漏传 session 参数等于白开事务:所有写操作会立即提交,回滚完全失效。每次调用 insert_one()、update_one()、delete_many() 等方法时,必须加 session=session聚合管道中用 out 或 merge 写入数据时,同样要传 session;否则写入脱离事务控制读操作默认不参与事务隔离,如需读已写未提交数据,得设 read_concern=ReadConcern("local"),但通常没必要with client.start_session() as session: with session.start_transaction(): collection_a.insert_one({"x": 1}, session=session) # ? 正确 collection_b.update_one({"y": 2}, {"$set": {"z": 3}}, session=session) # ? 正确 collection_a.insert_one({"x": 2}) # ? 没传 session,立刻提交,事务无法回滚它事务有 60 秒超时且不可配置从 start_transaction() 开始计时,超时后服务端自动中止事务并释放锁。不是客户端异常,所以 try/except 捕获不到;表现常是后续操作卡住或报 InvalidSession。避免在事务里做 HTTP 请求、文件读写、长循环等阻塞操作批量操作尽量用 insert_many()、bulk_write() 替代多次单条调用,减少网络往返和时间消耗如果真需要长流程,拆成多个短事务,用业务逻辑保证最终一致性,而不是强依赖单事务writeConcern 影响事务可见性与持久性事务提交时的 writeConcern 决定"成功"意味着什么。默认 w=1(主节点写入即返回),但主节点宕机可能丢数据;设 w="majority" 才能保证多数节点落盘。 橙篇 百度文库发布的一款综合性AI创作工具

相关推荐
2301_814809862 小时前
Layui表单提交时如何防止用户重复点击提交按钮
jvm·数据库·python
qq_413847402 小时前
SQL连接查询中处理NULL值的技巧_利用COALESCE处理JOIN结果
jvm·数据库·python
m0_734949792 小时前
mysql如何通过Docker快速搭建_mysql容器化部署实践
jvm·数据库·python
2301_796588502 小时前
Golang怎么处理JSON大数字精度_Golang如何避免前端JavaScript解析大整数丢失精度【避坑】
jvm·数据库·python
吕源林2 小时前
如何使用关联数组_Index-By Table集合类型定义与遍历
jvm·数据库·python
陶然同学2 小时前
【Python】文件操作
开发语言·python
2301_775148152 小时前
如何配置物化视图只进行完全刷新_COMPLETE Refresh的强制刷新场景
jvm·数据库·python
m0_743623922 小时前
HTML函数本地测试需多少带宽_HTML函数与网络硬件关系【操作】
jvm·数据库·python
YJlio2 小时前
2026年4月18日60秒读懂世界:从神舟二十号出舱到L2新国标公示,今天最值得关注的6个信号
windows·python·django·计算机外设·电脑·outlook·eixv3