您好,登錄后才能下訂單哦!
按照粒度由粗到細(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)文章!
免責(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)容。