成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

SpringBoot之使用Redis實(shí)現(xiàn)分布式鎖(秒殺系統(tǒng))

瀏覽:229日期:2023-03-15 13:06:41
一、Redis分布式鎖概念篇

建議直接采用Redis的官方推薦的Redisson作為redis的分布式鎖

1.1、為什么要使用分布式鎖

我們?cè)陂_發(fā)應(yīng)用的時(shí)候,如果需要對(duì)某一個(gè)共享變量進(jìn)行多線程同步訪問的時(shí)候,可以使用我們學(xué)到的Java多線程的18般武藝進(jìn)行處理,并且可以完美的運(yùn)行,毫無Bug!

注意這是單機(jī)應(yīng)用,也就是所有的請(qǐng)求都會(huì)分配到當(dāng)前服務(wù)器的JVM內(nèi)部,然后映射為操作系統(tǒng)的線程進(jìn)行處理!而這個(gè)共享變量只是在這個(gè)JVM內(nèi)部的一塊內(nèi)存空間!

后來業(yè)務(wù)發(fā)展,需要做集群,一個(gè)應(yīng)用需要部署到幾臺(tái)機(jī)器上然后做負(fù)載均衡,大致如下圖:

SpringBoot之使用Redis實(shí)現(xiàn)分布式鎖(秒殺系統(tǒng))

上圖可以看到,變量A存在JVM1、JVM2、JVM3三個(gè)JVM內(nèi)存中(這個(gè)變量A主要體現(xiàn)是在一個(gè)類中的一個(gè)成員變量,是一個(gè)有狀態(tài)的對(duì)象,例如:UserController控制器中的一個(gè)整形類型的成員變量),如果不加任何控制的話,變量A同時(shí)都會(huì)在JVM分配一塊內(nèi)存,三個(gè)請(qǐng)求發(fā)過來同時(shí)對(duì)這個(gè)變量操作,顯然結(jié)果是不對(duì)的!即使不是同時(shí)發(fā)過來,三個(gè)請(qǐng)求分別操作三個(gè)不同JVM內(nèi)存區(qū)域的數(shù)據(jù),變量A之間不存在共享,也不具有可見性,處理的結(jié)果也是不對(duì)的!

如果我們業(yè)務(wù)中確實(shí)存在這個(gè)場(chǎng)景的話,我們就需要一種方法解決這個(gè)問題!

為了保證一個(gè)方法或?qū)傩栽诟卟l(fā)情況下的同一時(shí)間只能被同一個(gè)線程執(zhí)行,在傳統(tǒng)單體應(yīng)用單機(jī)部署的情況下,可以使用Java并發(fā)處理相關(guān)的API(如ReentrantLock或Synchronized)進(jìn)行互斥控制。在單機(jī)環(huán)境中,Java中提供了很多并發(fā)處理相關(guān)的API。但是,隨著業(yè)務(wù)發(fā)展的需要,原單體單機(jī)部署的系統(tǒng)被演化成分布式集群系統(tǒng)后,由于分布式系統(tǒng)多線程、多進(jìn)程并且分布在不同機(jī)器上,這將使原單機(jī)部署情況下的并發(fā)控制鎖策略失效,單純的Java API并不能提供分布式鎖的能力。為了解決這個(gè)問題就需要一種跨JVM的互斥機(jī)制來控制共享資源的訪問,這就是分布式鎖要解決的問題!

1.2、分布式鎖應(yīng)具備哪些條件

在分析分布式鎖的三種實(shí)現(xiàn)方式之前,先了解一下分布式鎖應(yīng)該具備哪些條件:

1、在分布式系統(tǒng)環(huán)境下,一個(gè)方法在同一時(shí)間只能被一個(gè)機(jī)器的一個(gè)線程執(zhí)行;

2、高可用的獲取鎖與釋放鎖;

3、高性能的獲取鎖與釋放鎖;

4、具備可重入特性;

5、具備鎖失效機(jī)制,防止死鎖;

6、具備非阻塞鎖特性,即沒有獲取到鎖將直接返回獲取鎖失敗。

1.3、分布式鎖的三種實(shí)現(xiàn)方式

目前幾乎很多大型網(wǎng)站及應(yīng)用都是分布式部署的,分布式場(chǎng)景中的數(shù)據(jù)一致性問題一直是一個(gè)比較重要的話題。分布式的CAP理論告訴我們“任何一個(gè)分布式系統(tǒng)都無法同時(shí)滿足一致性(Consistency)、可用性(Availability)和分區(qū)容錯(cuò)性(Partition tolerance),最多只能同時(shí)滿足兩項(xiàng)。”所以,很多系統(tǒng)在設(shè)計(jì)之初就要對(duì)這三者做出取舍。在互聯(lián)網(wǎng)領(lǐng)域的絕大多數(shù)的場(chǎng)景中,都需要犧牲強(qiáng)一致性來換取系統(tǒng)的高可用性,系統(tǒng)往往只需要保證“最終一致性”,只要這個(gè)最終時(shí)間是在用戶可以接受的范圍內(nèi)即可。

在很多場(chǎng)景中,我們?yōu)榱吮WC數(shù)據(jù)的最終一致性,需要很多的技術(shù)方案來支持,比如分布式事務(wù)、分布式鎖等。有的時(shí)候,我們需要保證一個(gè)方法在同一時(shí)間內(nèi)只能被同一個(gè)線程執(zhí)行。

1、基于數(shù)據(jù)庫實(shí)現(xiàn)分布式鎖;

2、基于緩存(Redis等)實(shí)現(xiàn)分布式鎖;

3、基于Zookeeper實(shí)現(xiàn)分布式鎖;

盡管有這三種方案,但是不同的業(yè)務(wù)也要根據(jù)自己的情況進(jìn)行選型,他們之間沒有最好只有更適合!

二、Redis分布式鎖實(shí)戰(zhàn)篇2.1、導(dǎo)入依賴

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-redis</artifactId> <version>1.4.7.RELEASE</version></dependency>2.2、配置Redis配置信息

spring redis: port: 6379 host: 127.0.0.1 password: database: 02.3、配置RedisConfig屬性、如果需要使用FastJSON來序列化你的對(duì)象可以看看我前面寫的一篇文章

@Configurationpublic class RedisConfig { @Bean public RedisTemplate initRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws Exception {RedisTemplate redisTemplate = new RedisTemplate();redisTemplate.setConnectionFactory(redisConnectionFactory);redisTemplate.setKeySerializer(new StringRedisSerializer());redisTemplate.setValueSerializer(new JdkSerializationRedisSerializer());redisTemplate.setHashKeySerializer(new StringRedisSerializer());redisTemplate.setHashValueSerializer(new JdkSerializationRedisSerializer());redisTemplate.setDefaultSerializer(new StringRedisSerializer());redisTemplate.afterPropertiesSet();return redisTemplate; }}2.4、寫一個(gè)RedisLock工具類

/*** @Description //直接使用Redis進(jìn)行分布式鎖 * 這是簡(jiǎn)易版本 如果要使用Redis原生鎖記得加過期時(shí)間,防止死鎖 最好使用Redisson操作簡(jiǎn)單更加方便* @Date $ $* @Author huangwb**/ @Componentpublic class RedisLockCommon { @Autowired private StringRedisTemplate stringRedisTemplate; /** * Redis加鎖的操作 * * @param key * @param value * @return */ public Boolean tryLock(String key, String value) {if (stringRedisTemplate.opsForValue().setIfAbsent(key, value)) { return true;}String currentValue = stringRedisTemplate.opsForValue().get(key);if (StringUtils.isNotEmpty(currentValue) && Long.valueOf(currentValue) < System.currentTimeMillis()) { //獲取上一個(gè)鎖的時(shí)間 如果高并發(fā)的情況可能會(huì)出現(xiàn)已經(jīng)被修改的問題 所以多一次判斷保證線程的安全 String oldValue = stringRedisTemplate.opsForValue().getAndSet(key, value); if (StringUtils.isNotEmpty(oldValue) && oldValue.equals(currentValue)) {return true; }}return false; } /** * Redis解鎖的操作 * * @param key * @param value */ public void unlock(String key, String value) {String currentValue = stringRedisTemplate.opsForValue().get(key);try { if (StringUtils.isNotEmpty(currentValue) && currentValue.equals(value)) {stringRedisTemplate.opsForValue().getOperations().delete(key); }} catch (Exception e) {} }}2.5、減庫存操作

@Override public boolean decrementProductStore(Long productId, Integer productQuantity) {String key = 'dec_store_lock_' + productId;long time = System.currentTimeMillis();try { //如果加鎖失敗 if (!redisLock.tryLock(key, String.valueOf(time))) {return false; } ProductInfo productInfo = productInfoMapper.selectByPrimaryKey(productId); //如果庫存為空 if (productInfo.getProductStock() == 0) {return false; } //減庫存操作 productInfo.setProductStock(productInfo.getProductStock() - 1); productInfoMapper.updateByPrimaryKey(productInfo);} catch (Exception e) { e.printStackTrace(); return false;} finally { //解鎖 redisLock.unlock(key, String.valueOf(time));}return true; }2.6、測(cè)試接口

@GetMapping('test')public String createOrderTest() { if (!productInfoService.decrementProductStore(1L, 1)) {return '庫存不足'; } OrderMaster orderMaster = new OrderMaster(); //未支付 orderMaster.setOrderStatus(0); //未支付 orderMaster.setPayStatus(0); orderMaster.setBuyerName('張三'); orderMaster.setBuyerAddress('湖南長沙'); orderMaster.setBuyerPhone('18692794847'); orderMaster.setOrderAmount(BigDecimal.ZERO); orderMaster.setCreateTime(DateUtils.getCurrentDate()); orderMaster.setOrderId(UUID.randomUUID().toString().replaceAll('-', '')); orderMasterService.insert(orderMaster);}

2.7、可以使用使用Apache ab進(jìn)行http接口測(cè)試

具體文章可以看看這篇文章 https://www.jb51.net/article/177250.htm

三、結(jié)尾

到此這篇關(guān)于SpringBoot之使用Redis實(shí)現(xiàn)分布式鎖(秒殺系統(tǒng))的文章就介紹到這了,更多相關(guān)SpringBoot Redis分布式鎖內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

文章概覽篇來源于 https://blog.csdn.net/hxpjava1/article/details/81068355

標(biāo)簽: Spring
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美精品亚洲精品| 亚洲自拍偷拍图区| 亚洲综合激情小说| 亚洲福利久久| 中文字幕中文字幕在线一区 | 噜噜噜在线观看免费视频日韩| 国产精品久久久久国产精品日日| 9久草视频在线视频精品| 精品国产免费一区二区三区四区| 风间由美一区二区av101 | 日韩毛片精品高清免费| 国内精品久久久久久久影视蜜臀 | 国语自产精品视频在线看抢先版结局| 2021中文字幕一区亚洲| 国产aⅴ综合色| 欧美成人女星排名| eeuss影院一区二区三区 | 国产日韩欧美高清在线| 欧美 日韩 国产在线| 亚洲精品在线观看网站| 成人av在线资源网| 久久久久久久久蜜桃| 午夜日本精品| 亚洲欧洲日韩综合一区二区| 亚洲精品影视| 又紧又大又爽精品一区二区| 亚洲影视综合| 丝袜诱惑亚洲看片| 欧美亚一区二区| 国产精品自拍毛片| 欧美一级搡bbbb搡bbbb| 99精品视频在线播放观看| 国产人成亚洲第一网站在线播放 | 亚洲图片你懂的| 亚洲精品视频一区二区三区| 亚洲一区免费观看| 老**午夜毛片一区二区三区| 免费观看在线综合色| 欧美日韩亚州综合| 风间由美一区二区av101| 久久久久久久综合色一本| 欧美涩涩视频| 一区二区三区中文在线观看| 欧美主播一区二区三区美女 久久精品人| 三级影片在线观看欧美日韩一区二区| 色美美综合视频| 国产精品中文字幕一区二区三区| 精品成人在线观看| 亚洲国产mv| 爽好久久久欧美精品| 欧美日韩国产天堂| 99久久99久久精品免费观看 | 99国产精品私拍| 日韩激情一二三区| 欧美日韩国产另类一区| 成人av手机在线观看| 国产精品乱码妇女bbbb| 免费久久久一本精品久久区 | 99xxxx成人网| 免费高清视频精品| 精品久久久网站| 亚洲福利电影| 免费观看91视频大全| 日韩欧美色综合网站| 黄色av日韩| 日韩电影网1区2区| 欧美不卡一区二区三区| 在线日韩视频| 久久精品国产**网站演员| 精品对白一区国产伦| aa级大片欧美三级| 久久99国产乱子伦精品免费| 久久久国际精品| 亚洲一区亚洲| 国产成人免费网站| 国产精品大尺度| 欧洲av一区二区嗯嗯嗯啊| 国产69精品久久久久毛片| 亚洲欧洲美洲综合色网| 欧美亚洲禁片免费| 亚洲欧美一级二级三级| 午夜视频一区在线观看| 欧美xxxx在线观看| 中文日韩在线| 国产精品中文有码| 中文字幕一区二区日韩精品绯色| 91国偷自产一区二区三区观看| hitomi一区二区三区精品| 夜夜嗨av一区二区三区中文字幕| 欧美一区二区三区免费在线看| 亚洲精品一区二区三区樱花| 黄色日韩网站视频| 中文字幕一区二区三区四区| 欧美日韩一区二区三区四区| 亚洲天堂黄色| 国产精品1区2区3区在线观看| 中文字幕一区二区日韩精品绯色| 欧美日韩一卡二卡三卡| 一区一区视频| 国产一区二区91| 一区二区三区日韩| 精品剧情v国产在线观看在线| 男女精品网站| 欧美一区高清| 久久国产精品区| 亚洲欧美偷拍三级| 欧美不卡一区二区三区| 色综合久久88色综合天天免费| 欧美99在线视频观看| 久久99精品国产麻豆不卡| 亚洲欧美福利一区二区| 日韩精品中文字幕在线不卡尤物| 久久99伊人| 国内视频一区| 国产凹凸在线观看一区二区| 亚洲午夜私人影院| 国产清纯美女被跳蛋高潮一区二区久久w| 欧美午夜电影网| 国产日韩一区欧美| 99精品热视频| 久久成人久久爱| 亚洲伊人伊色伊影伊综合网| 久久久久久久久97黄色工厂| 欧美日韩国产一级片| 国产精品综合| 欧美日韩免费观看一区| 国产精品一级黄| 日韩精品每日更新| 亚洲丝袜美腿综合| 26uuu精品一区二区在线观看| 亚洲欧美日韩精品一区二区| 欧美另类视频| 成人听书哪个软件好| 日韩 欧美一区二区三区| 亚洲女同ⅹxx女同tv| 欧美激情一区二区在线| 欧美一区二区三区日韩| 欧美午夜精品久久久久久超碰| 国产欧美在线| 最新国产乱人伦偷精品免费网站| 91浏览器入口在线观看| 国产美女精品人人做人人爽| 日韩不卡一区二区三区| 亚洲综合色自拍一区| 国产精品理论片在线观看| 久久综合久久综合九色| 日韩欧美国产综合一区| 欧美精选午夜久久久乱码6080| 在线欧美小视频| 久久久久久精| 午夜一区二区三视频在线观看| 伊人久久婷婷| 国内揄拍国内精品久久| 欧美日韩a区| 91看片淫黄大片一级在线观看| 成人综合激情网| 国产精品亚洲一区二区三区在线| 老司机午夜精品99久久| 日日夜夜精品视频免费| 亚洲一区二区视频| 亚洲影视在线观看| 亚洲一区免费在线观看| 亚洲一区在线视频| 亚洲最色的网站| 一区二区在线观看免费| 亚洲视频电影在线| 亚洲美女视频在线| 亚洲嫩草精品久久| 亚洲精品ww久久久久久p站| ...av二区三区久久精品| 国产精品家庭影院| 日韩美女啊v在线免费观看| 亚洲视频免费观看| 亚洲柠檬福利资源导航| 综合色中文字幕| 亚洲精品国产a| 亚洲无线码一区二区三区| 亚洲一区二区三区三| 午夜精彩视频在线观看不卡| 日韩av一级片| 伦理电影国产精品| 精品夜夜嗨av一区二区三区| 国产资源在线一区| 丁香激情综合五月| av在线一区二区| 欧美激情 亚洲a∨综合| 国产精品高清一区二区三区| 亚洲黄色高清| 六月天综合网| 久久永久免费| 欧美日韩卡一卡二| 日韩视频一区在线观看| 久久美女艺术照精彩视频福利播放| 国产欧美日韩麻豆91| 亚洲视频综合在线| 午夜精品久久一牛影视| 裸体一区二区三区| 丁香亚洲综合激情啪啪综合| 欧美99久久| aⅴ色国产欧美|