MongoDB事务和隔离级别的原理

目录

写操作事务原理

读操作事务原理

隔离级别

多文档事务ACID

持久性

隔离性

一致性

原子性


写操作事务原理

保证持久性

MongoDB参数weiteConcern决定写操作落到多少个节点内存上才算成功

0 发起写操作,不关心成功

1~最大集群数 写操作需要被复杂到指定节点数才算成功

majority 写操作需要被复制到大多节点上才算成功 默认值

all 写操作需要被复制到全部节点上才算成功

journal日志

journal日志

和MySQL的redo log日志一样,都是预写日志,先持久化日志,然后根据日志对MongoDB进行修改

可以对数据进行崩溃恢复,但是不能进行备份,因为和redo log一样是覆盖写

MongoDB会先写入到journal日志,然后再进行复制节点数据到内存

false 写入到内存就返回成功 默认值

true 写入到磁盘才返回成功

一般是在性能和持久化的程度取舍

一般可以在MongoDB Shell 命令指定

读操作事务原理

readPreference参数决定MongoDB在那个节点上面读取数据

primary 只在主节点上面读数据 默认值

primaryPreferred 优先选择主节点,不可用使用从节点

seondary 只选择从节点

secondaryPreferred 优先选择从节点,如果从节点不可用使用主节点

nearest 选择最近的节点

实时性要求高的使用主节点读取,实时性不高的使用从节点读取,分布广的使用选择最近节点

一般可以在MongoDB Shell 命令指定或者当做链接参数

隔离级别

readConcern参数决定这个节点上数据那些可以读取,就是类比MySQL的隔离级别

available 读取所有这个节点上的数据

local 读取在这个节点并且完成当前分片的数据 默认值

majority 读取在大多数节点上提交完成的数据 实现原理MVCC版本控制

linearizable 保证操作线性化读取文档

snapshot 仅在事务中生效,在事务中才能设置读取最近快照中的数据 实现原理MVCC版本控制

available 和 local 类似 MySQL的读未提交

majority 类似 MySQL的读已提交

snapshot 类似 MySQL的可重复读 在事务中才能设置

linearizable 类似 MySQL的串行化

多文档事务ACID

类似MySQL的ACID 原理类比MySQL进行理解,差不多

原子性、一致性、隔离性、持久性

事务可以不用就不要用,因为涉及到事务意味着锁、节点协调、额外开销、性能影响

持久性

journal日志和参数weiteConcern决定落到多少节点返回成功实现

隔离性

使用readConcern参数决定这个节点上数据那些可以读取实现

一致性

各个节点保证一致 确保数据的正确和完整 通过持久性和隔离性实现的

原子性

要么全部成功,要么全部失败

MongoDB原子性使用方法

开启一个session、开始事务 、操作 、提交事务,有相应的API进行调用即可

MongoDB使用事务日志进行记录,只在提交的时候通过事务日志进行节点的修改,保证事务的原子性

事务日志如果是单节点的话就是 journal日志,如果是多节点需要其他日志进行协调

相关推荐
马克Markorg5 小时前
常见的向量数据库和具有向量数据库能力的数据库
数据库
Coder_Boy_8 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy8 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道9 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707539 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha9 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_10 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance10 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋10 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.10 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库