依照粒度由粗到細:
以商品詳情頁為例
#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中文網其他相關文章!