关于Redis中事务

作者 : admin 本文共623个字,预计阅读时间需要2分钟 发布时间: 2024-06-10 共2人阅读

事务的四个特性

Redis到底有没有原子性

Redis中的原子性不同于MySQL,相比于MySQL,Redis中的原子性几乎不值一提。

MySQL中的原子性,不仅仅是“要么全都执行,要么全都不执行”,它还保证了“一旦执行,结果就必须是正确的”,如果不正确,就会进行回滚操作,保证不会出现错误的数据。

但Redis中的原子性,仅仅就是把多个操作打包在一起执行,只是保证这些操作要么都不执行,要么都执行,并不保证结果是正确的。

Redis不具备一致性

Redis没有约束,也没有回滚机制,事务执行过程中如果某个修改操作出现失败,就可能引起不一致的情况。

Redis不具备持久性

Redis本身就是内存数据库,数据是存储在内存中的,虽然Redis也有持久化机制,但这个机制跟事务没有半毛钱关系。

Redis不涉及隔离性

Redis是一个单线程模型的服务器程序,所有的请求/事务,都是“串行”执行的。

Redis中事务的意义

Redis中的事务,主要的意义,就是为了“打包”,避免其他客户端的命令插队到中间

Redis中通过引入队列来实现事务。开启事务的时候,客户端输入的命令会发给服务器,并进入这个队列中,而不是立即执行。当遇到“执行事务”命令的时候,就会把队列中的这些食物按照顺序依次执行。Redis主线程会把事务中的操作执行完毕之后,再处理别的客户端。

什么时候需要用到Redis的事务?

当需要对多个操作进行打包执行的时候(一般是为了防止线程安全问题),使用事务是比较合适的。

本站无任何商业行为
个人在线分享 » 关于Redis中事务
E-->