日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > windows >内容正文

windows

阿里云Redis读写分离典型场景:如何轻松搭建电商秒杀系统

發(fā)布時(shí)間:2024/7/5 windows 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 阿里云Redis读写分离典型场景:如何轻松搭建电商秒杀系统 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

秒殺活動(dòng)是絕大部分電商選擇的低價(jià)促銷,推廣品牌的方式。不僅可以給平臺帶來用戶量,還可以提高平臺知名度。一個(gè)好的秒殺系統(tǒng),可以提高平臺系統(tǒng)的穩(wěn)定性和公平性,獲得更好的用戶體驗(yàn),提升平臺的口碑,從而提升秒殺活動(dòng)的最大價(jià)值。

本次主要討論阿里云云數(shù)據(jù)庫Redis緩存設(shè)計(jì)高并發(fā)的秒殺系統(tǒng)。

秒殺的特征

秒殺活動(dòng)對稀缺或者特價(jià)的商品進(jìn)行定時(shí),定量售賣,吸引成大量的消費(fèi)者進(jìn)行搶購,但又只有少部分消費(fèi)者可以下單成功。因此,秒殺活動(dòng)將在較短時(shí)間內(nèi)產(chǎn)生比平時(shí)大數(shù)十倍,上百倍的頁面訪問流量和下單請求流量。

秒殺活動(dòng)可以分為3個(gè)階段:

  • 秒殺前:用戶不斷刷新商品詳情頁,頁面請求達(dá)到瞬時(shí)峰值。

  • 秒殺開始:用戶點(diǎn)擊秒殺按鈕,下單請求達(dá)到瞬時(shí)峰值。

  • 秒殺后:一部分成功下單的用戶不斷刷新訂單或者產(chǎn)生退單操作,大部分用戶繼續(xù)刷新商品詳情頁等待退單機(jī)會(huì)。

消費(fèi)者提交訂單,一般做法是利用數(shù)據(jù)庫的行級鎖。只有搶到鎖的請求可以進(jìn)行庫存查詢和下單操作。但是在高并發(fā)的情況下,數(shù)據(jù)庫無法承擔(dān)如此大的請求,往往會(huì)使整個(gè)服務(wù)blocked,在消費(fèi)者看來就是服務(wù)器宕機(jī)。

秒殺系統(tǒng)

系統(tǒng)架構(gòu)圖

秒殺系統(tǒng)的流量雖然很高,但是實(shí)際有效流量是十分有限的。利用系統(tǒng)的層次結(jié)構(gòu),在每個(gè)階段提前校驗(yàn),攔截?zé)o效流量,可以減少大量無效的流量涌入數(shù)據(jù)庫。

利用瀏覽器緩存和CDN抗壓靜態(tài)頁面流量

秒殺前,用戶不斷刷新商品詳情頁,造成大量的頁面請求。所以,我們需要把秒殺商品詳情頁與普通的商品詳情頁分開。對于秒殺商品詳情頁盡量將能靜態(tài)化的元素盡量靜態(tài)化處理,除了秒殺按鈕需要服務(wù)端進(jìn)行動(dòng)態(tài)判斷,其他的靜態(tài)數(shù)據(jù)可以緩存在瀏覽器和CDN上。這樣,秒殺前刷新頁面導(dǎo)致的流量進(jìn)入服務(wù)段的流量只有很小的一部分

利用阿里云讀寫分離Redis緩存攔截流量

CDN是第一級流量攔截,第二級流量攔截我們使用支持讀寫分離的阿里云Redis。在這一階段我們主要讀取數(shù)據(jù),讀寫分離Redis能支持高大60萬以上qps的,完全可以支持需求。

首先通過數(shù)據(jù)控制模塊,提前將秒殺商品的緩存到阿里云讀寫分離Redis,并設(shè)置秒殺開始標(biāo)記:

"goodsId_count": 100 //總數(shù)"goodsId_start": 0 //開始標(biāo)記"goodsId_access": 0 //接受下單數(shù)

秒殺開始前,服務(wù)集群讀取goodsId_Start為0,直接返回未開始。

數(shù)據(jù)控制模塊將goodsId_start改為1,標(biāo)志秒殺開始。

服務(wù)集群緩存開始標(biāo)記位并開始接受請求,并記錄到redis中g(shù)oodsId_access,商品剩余數(shù)量為(goodsId_count - goodsId_access)。

當(dāng)接受下單數(shù)達(dá)到goodsId_count后,繼續(xù)攔截所有請求,商品剩余數(shù)量為0

可以看出,最后成功參與下單的請求只有少部分可以被接受。在高并發(fā)的情況下,允許稍微多的流量進(jìn)入。因此可以控制接受下單數(shù)的比例。

利用阿里云主從版Redis緩存加速庫存扣量

成功參與下單,進(jìn)入下層服務(wù),開始進(jìn)行訂單信息校驗(yàn),庫存扣量。為了避免直接訪問數(shù)據(jù)庫,我們使用阿里云主從版Redis來進(jìn)行庫存扣量,阿里云主從版Redis提供10萬級別的QPS。我們使用Redis來優(yōu)化庫存查詢,提前攔截秒殺失敗的請求,將大大提高系統(tǒng)的整體吞吐量。我們也是通過數(shù)據(jù)控制模塊提前將庫存存入Redis:

//我們將每個(gè)秒殺商品在redis中用一個(gè)hash結(jié)構(gòu)表示

"goodsId" : { "Total": 100 "Booked": 100}

扣量時(shí),服務(wù)器通過請求Redis獲取下單資格,我們通過lua腳本實(shí)現(xiàn),由于Redis時(shí)單線程模型,lua可以保證多個(gè)命令的原子性:

lua腳本:

local n = tonumber(ARGV[1])if not n or n == 0 then return 0 end local vals = redis.call("HMGET", KEYS[1], "Total", "Booked");local total = tonumber(vals[1])local blocked = tonumber(vals[2])if not total or not blocked then return 0 end if blocked + n <= total then redis.call("HINCRBY", KEYS[1], "Booked", n) return n; end return 0

先使用SCRIPT LOAD將lua腳本提前緩存在Redis,然后調(diào)用EVALSHA調(diào)用腳本,比直接調(diào)用EVAL節(jié)省網(wǎng)絡(luò)帶寬:

redis 127.0.0.1:6379>SCRIPT LOAD "lua code""438dd755f3fe0d32771753eb57f075b18fed7716" redis 127.0.0.1:6379>EVAL 438dd755f3fe0d32771753eb57f075b18fed7716 1 goodsId 1

秒殺服務(wù)通過判斷Redis是否返回?fù)屬弬€(gè)數(shù)n,即可知道此次請求是否扣量成功。

使用阿里云主從版Redis實(shí)現(xiàn)簡單的消息隊(duì)列異步下單入庫

扣量完成后,需要進(jìn)行訂單入庫。如果商品數(shù)量較少的時(shí)候,直接操作數(shù)據(jù)庫即可。如果秒殺的商品是1萬,甚至10萬級別,那數(shù)據(jù)庫鎖沖突將帶來很大的性能瓶頸。因此,利用消息隊(duì)列組件,當(dāng)秒殺服務(wù)將訂單信息寫入消息隊(duì)列后,即可認(rèn)為下單完成,避免直接操作數(shù)據(jù)庫。

消息隊(duì)列組件依然可以使用Redis實(shí)現(xiàn),在R2中用list數(shù)據(jù)結(jié)構(gòu)表示:

orderList { [0] = {訂單內(nèi)容} [1] = {訂單內(nèi)容} [2] = {訂單內(nèi)容} ...}

將訂單內(nèi)容寫入Redis:

LPUSH orderList {訂單內(nèi)容}

異步下單模塊從Redis中順序獲取訂單信息,并將訂單寫入數(shù)據(jù)庫:

BRPOP orderList 0

我們通過使用Redis作為消息隊(duì)列,異步處理訂單入庫,有效的提高了用戶的下單完成速度。

數(shù)據(jù)控制模塊,管理秒殺數(shù)據(jù)同步

最開始,我們利用阿里云讀寫分離Redis進(jìn)行流量限制,只讓部分流量進(jìn)入下單。對于下單檢驗(yàn)失敗和退單等情況,我們需要讓更多的流量進(jìn)來。因此,數(shù)據(jù)控制模塊需要定時(shí)將數(shù)據(jù)庫中的數(shù)據(jù)進(jìn)行一定的計(jì)算,同步到主從版Redis,同時(shí)再同步到讀寫分離的Redis,讓更多的流量進(jìn)來。

總結(jié)

以上是生活随笔為你收集整理的阿里云Redis读写分离典型场景:如何轻松搭建电商秒杀系统的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。