首頁  >  文章  >  資料庫  >  redis多層快取介紹

redis多層快取介紹

尚
轉載
2020-05-02 09:07:542996瀏覽

redis多層快取介紹

依照粒度由粗到細:

以商品詳情頁為例

#1、頁面層級快取

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

2、物件層級快取

(如商品數據,(key=  商品id,val=「資料庫查出的商品資料」)將查詢過一次的商品資訊存到redis,第二次請求改商品資料時,優先到redis查詢)

redis做快取的想法是:

1、先檢查redis有無資料

1.1、有就回傳

1.2、沒有,就查詢資料庫,存入redis,再回傳

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

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

redis在秒殺中的使用:

#1、先將秒殺商品庫存預存到redis

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

3、如果為了減輕對redis的存取壓力,可以將使用者提交的秒殺請求放到mq(例如RabbitMq)中

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

3.1、可以將請求放到訊息佇列中,回傳給前端是「排隊中";

3.2、消費者(佇列的」消費者「)按照固定的速度從訊息佇列中取數據,創建訂單到資料庫(也有條不紊的創建10個訂單,資料庫0衝擊),

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

3.4、創建訂單成功的請求,將該請求從mq中移除,對用戶發送短信”恭喜,秒殺成功!「

3.5、成功創建10個訂單之後(也就是秒殺結束),給隊列中其他用戶請求返回」秒殺失敗「

更多redis知識請關注redis入門教學欄位。

以上是redis多層快取介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除