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

相关推荐
aqi007 小时前
15天学会AI应用开发(十)把文本嵌入模型换成国产模型
人工智能·python·ai编程
吃糖的小孩8 小时前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
金銀銅鐵1 天前
[Python] 扩展欧几里得算法
python·数学·算法
Duckdblab1 天前
DuckDB 性能调优终极指南:打造闪电般的分析体验
python
带派擂总1 天前
Python全栈开发精华版最全合集(包含各种面试题) Day24_异常和错误
python
笃行3501 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3501 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3501 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
金銀銅鐵1 天前
n^5 和 n 的个位数是否总相等?
python·数学