在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

redis单线程需要加锁的原因

102次阅读
没有评论

共计 912 个字符,预计需要花费 3 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关 redis 单线程需要加锁的原因,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

个人理解是,虽然 redis 是单线程,但是可以同时有多个客户端访问,每个客户端会有一个线程。客户端访问之间存在竞争。

因为存在多客户端并发,所以必须保证操作的原子性。比如银行卡扣款问题,获取余额,判断,扣款,写回就必须构成事务,否则就可能出错。

在传统单体应用单机部署的情况下,可以使用 Java 并发相关的锁,如 ReentrantLcok 或 synchronized 进行互斥控制。但是,随着业务发展的需要,原单体单机部署的系统,渐渐的被部署在多机器多 JVM 上同时提供服务,这使得原单机部署情况下的并发控制锁策略失效了,为了解决这个问题就需要一种跨 JVM 的互斥机制来控制共享资源的访问,这就是分布式锁要解决的问题。

分布式锁的实现条件

1、互斥性,和单体应用一样,要保证任意时刻,只能有一个客户端持有锁

2、可靠性,要保证系统的稳定性,不能产生死锁

3、一致性,要保证锁只能由加锁人解锁,不能产生 A 的加锁被 B 用户解锁的情况

Redis 实现分布式锁不同的人可能有不同的实现逻辑。

分布式环境下,数据一致性问题一直是一个比较重要的话题,而又不同于单进程的情况。分布式与单机情况下最大的不同在于其不是多线程而是多进程。多线程由于可以共享堆内存,因此可以简单的采取内存作为标记存储位置。而进程之间甚至可能都不在同一台物理机上,因此需要将标记存储在一个所有进程都能看到的地方。

常见的是秒杀场景,订单服务部署了多个实例。如秒杀商品有 4 个,第一个用户购买 3 个,第二个用户购买 2 个,理想状态下第一个用户能购买成功,第二个用户提示购买失败,反之亦可。而实际可能出现的情况是,两个用户都得到库存为 4,第一个用户买到了 3 个,更新库存之前,第二个用户下了 2 个商品的订单,更新库存为 2,导致出错。

关于 redis 单线程需要加锁的原因就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计912字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: www.色午夜.com | 手机在线看片 | 久久福利青草免费精品 | 精品97国产免费人成视频 | 黄色毛片免费视频 | 大战熟女丰满人妻av | 国产高清精品久久久久久久 | 国产成人精品日本亚洲11 | 亚洲熟妇无码乱子av电影 | 国产精品视频一区麻豆 | 国产日韩久久久久69影院 | 97在线观看成人免费视频 | 四虎久久精品国产 | 加勒比久草| 日本特级淫片免费 | 久久精品免费i 国产 | 精品国产欧美另类一区 | 有色视频在线观看免费高清 | 亚洲色偷偷综合亚洲avyp | 亚洲国产一二三精品无码 | 伊人久久大香线蕉综合bd高清 | 国产∨亚洲v天堂无码久久久 | 一个色综合亚洲色综合 | 欧美成人在线免费视频 | 精品国产aⅴ无码一区二区 精品国产av 无码一区二区三区 | 亚洲第一天堂无码专区 | 久草视频首页 | 亚洲欧美综合精品成 | 任你操在线视频免费观看 | 日韩国产欧美成人一区二区影院 | 亚洲av首页在线观看 | 啪啪黄色 | 久久久无码一区二区三区 | 成人网站免费观看 | 一级待一黄aaa大片在线还看 | 亚洲国产精品一区二区第四页 | 亚洲精品456在线播放 | 国产自精品 | 成人做爰69片免费看网站野花 | 久久精品亚洲99一区二区 | 久久精品人妻无码一区二区三区 |