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

redis单线程需要加锁的原因

117次阅读
没有评论

共计 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字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 精品动漫一区二区三区 | 精品日韩一区二区三区视频 | 无遮挡一级毛片呦女视频 | 在线黄色网页 | 欧美a级情欲片在线观看免费 | 国产日韩欧美一区 | 亚洲视屏在线观看 | 四虎社区 | 亚洲av无码日韩精品影片 | 久久精品视频在线 | 538prom国产在线视频一区 | 香蕉久久高清国产精品免费 | 亚洲av无码一区二区三区观看 | 成人无遮挡18禁免费视频 | 青青草在久久免费久久免费 | 欧洲国产伦久久久久久久 | 色噜噜视频 | 91看片淫黄大片一级在线观看 | 久久亚洲av成人出白浆无码国产 | 日韩在线中文 | 国产 日韩 一区 | a级做爰视频免费观看 | 99热官网| 久久 国产 尿 小便 嘘嘘 | 日本黄色性视频 | 中文字幕无码乱人伦 | 国产一区二区三区在线观看视频 | 成人福利网址永久在线观看 | 欧美极度丰满熟妇hd | 国产精品福利视频一区二区三区 | 国产人成免费视频 | 国产成人精品综合 | 久久99国产综合色 | 国产小视频免费在线观看 | 在线综合亚洲欧美自拍 | 9i9精品国产免费久久 | 波多野结衣爽到高潮大喷 | 天天摸夜添狠狠添高 | 在线播放美女视频网站 | 中文字幕不卡一区 | 韩国美女丝袜一区二区 |