<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
(1)定義
全域性ID生成器,是一種在分散式系統下用來生成全域性唯一ID的工具,一半滿足下列特性:
為了增加ID的安全性,我們不直接使用Redis自增的數值,而是拼接一些其他的資訊。
ID的組成部分:
(2)程式碼實現
@Component public class RedisIdWorker { /** * 開始時間戳 */ private static final long BEGIN_TIMESTAMP = 1640995200L; /** * 序列號的位數 */ private static final int COUNT_BITS = 32; @Autowired private StringRedisTemplate stringRedisTemplate; public long nextId(String keyPrefix) { // 1.生成時間戳 LocalDateTime now = LocalDateTime.now(); long nowSecond = now.toEpochSecond(ZoneOffset.UTC); long timestamp = nowSecond - BEGIN_TIMESTAMP; // 2.生成序列號 // 2.1.獲取當前日期,精確到天 String date = now.format(DateTimeFormatter .ofPattern("yyyy:MM:dd")); // 2.2.自增長 long count = stringRedisTemplate.opsForValue() .increment("icr:" + keyPrefix + ":" + date); // 3.拼接並返回 return timestamp << COUNT_BITS | count; } }
(3)總結
全域性唯一ID生成策略:
Redis自增ID策略:
超賣問題是典型的多執行緒安全問題,針對這一問題的常見解決方案就是加鎖:
悲觀鎖
認為執行緒安全問題一定會發生,因此在運算元據之前先獲取鎖,確保執行緒序列執行。例如Synchronized、Lock都屬於悲觀鎖
樂觀鎖
認為執行緒安全問題不一定會發生,因此不加鎖,只是在更新資料時去判斷有沒有其他執行緒對資料進行了修改。如果沒有修改則認為是安全的,自己才更新資料;如果已經被其他執行緒修改,說明了安全問題,此時可以重試或異常。
樂觀鎖的關鍵是判斷之前查詢得到的資料是否有被修改過,常見的方式有兩種:
(1)版本號法
(2)CAS法
(3)總結
悲觀鎖 | 樂觀鎖 | |
---|---|---|
方案 | 新增同步鎖,讓執行緒序列執行 | 不加鎖,在更新時判斷是否有其他執行緒在修改 |
優點 | 簡單粗暴 | 效能好 |
缺點 | 效能一般 | 存在成功率低的問題 |
(1)Lua指令碼邏輯
判斷庫存是否充足:利用String型別
判斷使用者是否下單:利用Set型別
(2)java執行Lua指令碼邏輯
(3)程式碼
-- 1.參數列
-- 1.1.優惠券id
local voucherId = ARGV[1]
-- 1.2.使用者id
local userId = ARGV[2]-- 2.資料key
-- 2.1.庫存key
local stockKey = 'seckill:stock:' .. voucherId
-- 2.2.訂單key
local orderKey = 'seckill:order:' .. voucherId-- 3.指令碼業務
-- 3.1.判斷庫存是否充足 get stockKey
if(tonumber(redis.call('get', stockKey)) <= 0) then
-- 3.2.庫存不足,返回1
return 1
end
-- 3.2.判斷使用者是否下單 SISMEMBER orderKey userId
if(redis.call('sismember', orderKey, userId) == 1) then
-- 3.3.存在,說明是重複下單,返回2
return 2
end
-- 3.4.扣庫存 incrby stockKey -1
redis.call('incrby', stockKey, -1)
-- 3.5.下單(儲存使用者)sadd orderKey userId
redis.call('sadd', orderKey, userId)
return 0
private static final DefaultRedisScript<Long> SECKILL_SCRIPT; static { SECKILL_SCRIPT = new DefaultRedisScript<>(); SECKILL_SCRIPT.setLocation(new ClassPathResource("seckill.lua")); SECKILL_SCRIPT.setResultType(Long.class); } @Override public Result seckillVoucher(Long voucherId) { Long userId = UserHolder.getUser().getId(); long orderId = redisIdWorker.nextId("order"); // 1.執行lua指令碼 Long result = stringRedisTemplate.execute( SECKILL_SCRIPT, Collections.emptyList(), voucherId.toString(), userId.toString() ); int r = result.intValue(); // 2.判斷結果是否為0 if (r != 0) { // 2.1.不為0 ,代表沒有購買資格 return Result.fail(r == 1 ? "庫存不足" : "不能重複下單"); } // 3.傳送訊息佇列 非同步 // 4.返回訂單id return Result.ok(orderId); }
訊息佇列(Message Queue),字面意思就是存放訊息的佇列。最簡單的訊息佇列模型包括3個角色:
Redis提供了三種不同的方式來實現訊息佇列:
訊息佇列就是存放訊息的佇列。而Redis的List資料結構是一個雙向連結串列,很容易模擬。
佇列是入口和出口不在一邊,因此可以利用LPUSH結合RPOP來實現。
實現阻塞效果,應該使用BRPOP。
描述 | |
---|---|
優點 | 1、利用Redis儲存,不受限於JVM記憶體上限; 2、基於Redis的持久化機制,資料安全性有保障 3、可以滿足訊息有序性 |
缺點 | 1、無法避免訊息丟失 2、只支援單消費者 |
釋出訂閱模式,消費者可以訂閱一個或多個channel,生產者向對應channel傳送訊息後,所有訂閱者都能收到相關訊息。
描述 | |
---|---|
優點 | 1、採用釋出訂閱模式,支援多生產、多消費 |
缺點 | 1、不支援資料持久化 2、無法避免訊息丟失 3、訊息堆積有上限,超出時資料丟失 |
(1)基本用法
是Redis 5.0引入的新資料
特點:
(2)消費者組
消費者組(Consumer Group):將多個消費者劃分到一個組中,監聽同一個佇列。特點如下:
確認pending-list
檢視pendingList
特點:
List | PubSub | Stream | |
---|---|---|---|
訊息持久化 | 支援 | 不支援 | 支援 |
阻塞讀取 | 支援 | 支援 | 支援 |
訊息堆積處理 | 受限於記憶體空間,可以利用多消費者加快處理 | 受限於消費者緩衝區 | 受限於佇列長度,可以利用消費者組提高訊息速度,減少堆積 |
訊息回溯 | 不支援 | 不支援 | 支援 |
到此這篇關於Redis秒殺實現方案講解的文章就介紹到這了,更多相關Redis秒殺內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45