溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

redis如何實現(xiàn)多級緩存

發(fā)布時間:2020-05-20 14:45:16 來源:億速云 閱讀:639 作者:鴿子 欄目:關(guān)系型數(shù)據(jù)庫

                                                           redis如何實現(xiàn)多級緩存

按照粒度由粗到細(xì):

以商品詳情頁為例

1、頁面級別緩存

(有時也叫url級別緩存,將頁面手動渲染存到redis(key=商品id,val="商品詳情頁面,以后再次請求這個頁面時,從redis中獲取,直接向前端返回text/html,并且可以告訴瀏覽器在本地緩存該頁面,缺點是頁面數(shù)據(jù)更新不及時)

2、對象級別緩存

(如商品數(shù)據(jù),(key=  商品id,val=“數(shù)據(jù)庫查出的商品數(shù)據(jù)”)將查詢過一次的商品信息存到redis,第二次請求改商品數(shù)據(jù)時,優(yōu)先到redis查詢)

redis做緩存的思路是:

1、先檢查redis有無數(shù)據(jù)

1.1、有就返回

1.2、沒有,就查詢數(shù)據(jù)庫,存入redis,再返回

2、注意緩存的生命周期,

如果周期是永久,那么redis很容易崩掉,只是時間的問題

redis在秒殺中的使用:

1、先將秒殺商品庫存預(yù)存到redis

2、秒殺開始后,在redis中預(yù)減庫存,減為0該商品秒殺結(jié)束(redis是單線程的)

3、如果為了減輕對redis的訪問壓力,可以將用戶提交的秒殺請求放到mq(比如RabbitMq)中

比如一共只有10件商品,一共有10萬用戶虎視眈眈,都幾乎同一時間提交秒殺請求,

3.1、可以將請求放到消息隊列中,返回給前端是“排隊中";

3.2、消費者(隊列的”消費者“)按照固定的速度從消息隊列中取數(shù)據(jù),創(chuàng)建訂單到數(shù)據(jù)庫(也就有條不紊的創(chuàng)建10個訂單,數(shù)據(jù)庫0沖擊),

3.3、雖然有可能是排到前10的用戶,如果由于某種原因創(chuàng)建訂單失敗,就會將該用戶的秒殺請求放到mq尾部,接著給隊列中的其他用戶創(chuàng)建訂單

3.4、創(chuàng)建訂單成功的請求,將該請求從mq中移除,對用戶發(fā)送短信”恭喜,秒殺成功!“

3.5、成功創(chuàng)建10個訂單之后(也就是秒殺結(jié)束),給隊列中其他用戶請求返回”秒殺失敗“

以上就是redis多級緩存介紹的詳細(xì)內(nèi)容,更多請關(guān)注億速云其它相關(guān)文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI