如何在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创作工具

相关推荐
2501_9010064713 小时前
C#怎么实现配置热更新 C#如何在运行时动态刷新配置文件不需要重启程序【技巧】
jvm·数据库·python
m0_4708576413 小时前
HTML怎么创建响应式图片备选方案_HTML srcset与sizes结构【详解】
jvm·数据库·python
lifewange13 小时前
PostgreSQL介绍
数据库·postgresql
oradh14 小时前
Oracle数据库中的Java概述
java·数据库·oracle·sql基础·oracle数据库java概述
2301_7950997414 小时前
如何优化SQL中大批量数据的物理删除_分批次与间隔控制
jvm·数据库·python
阿kun要赚马内14 小时前
后端数据操作组合:Pydantic与ORM
后端·python·orm·sqlalchemy
2301_8125396714 小时前
CSS如何引入CSS形状生成器_通过自定义属性实现图形化样式
jvm·数据库·python
maxmaxma15 小时前
Claude Code集成DeepSeek-V4-pro全栈开发 - MCP 连接数据库
数据库·ai
lb291715 小时前
navicat连接Oracle报错了:“身份证明检索失败”
数据库·oracle·连接oracle数据库报错
xfhuangfu15 小时前
Oracle 12.2 ORA-600 数据库发生重启案例
数据库·oracle