redis是否支持原子操作


本文摘自PHP中文网,作者anonymity,侵删。

理论知识:

Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。

原子性(atomicity):一个事务是一个不可分割的最小工作单位,要么都成功要么都失败。

原子操作是指你的一个业务逻辑必须是不可拆分的。

比如你给别人转钱,你的账号扣钱,别人的账号增加钱,这个业务逻辑就是原子性的,这个操作就是原子操作,要么都成功要么都失败。

Redis所有单个命令的执行都是原子性的。

redis 实现事务的原理

1. 批量操作在发送 EXEC 命令前被放入队列缓存

2. 收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令都不会被执行

3. 在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中

以上就是redis是否支持原子操作的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

总结分享一些关于Redis缓存的面试题

Redis和简单的map有什么区别

Redis索引是什么

怎么提高Redis缓存命中率

什么是Redis

增加Redis命令的方法

详解Redis的lru算法

Redis如何集群

如何实现高可用的Redis集群

Redis除了缓存还能做什么

更多相关阅读请进入《Redis》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...