日常專案中快取穿透處理
阿新 • • 發佈:2022-02-12
說起快取穿透,大家都知道, 真正在使用過程中,很少有人感覺會快取穿透, 其實在我們日常開發過程中,不知不覺 你就寫了個bug , 下邊是我們開發中發現的一種快取穿透寫法, 僅供參考:
快取穿透寫法
/* 錯誤寫法示例 * * 解讀: * * 當 $data_list 查詢結果為空時候, 會導致 msgpack_pack 壓縮後 儲存快取結果為空 * 從快取取出資料時候, msgpack_unpack 解壓後,資料也是空值,從而導致 一直無法命中快取, */ public static function getList(){ $cache_key= 'richerdyoung.com:v1'; $redis = new Redis(); $data_list = msgpack_unpack($redis->get($cache_key)); if(empty($data_list)){ $data_list = getListByDb(); $redis->set($cache_key,msgpack_pack($data_list),86400); } return $data_list; }
正確寫法
/* 正確寫法 * 解讀 * * 當取出 不存在的 $cache_key 結果會返回 false ,此時查詢db , 如果db返回空,存入 redis * 第二次查詢 $cache_key ,快取key存在,但是結果為空,直接返回, 從而避免 重複查詢DB * * 也可以使用 $redis->exists($cache_key) 去判定版權屬於:依然範兒特西 本文連結:https://richerdyoung.com/p/111.html 作品採用:《署名-非商業性使用-相同方式共享 4.0 國際 (CC BY-NC-SA 4.0)》許可協議授權*/ public static function getAllAdOwnerignoreUserTypeList(){ $cache_key = 'richerdyoung.com:v1'; $redis = new Redis(); $cache_data_list = $redis->get($cache_key); if($cache_data_list === false){ $data_list = getListByDb(); $redis->set($cache_key,msgpack_pack($data_list),86400); }else{ $data_list = msgpack_unpack($cache_data_list); } return $data_list; }