flask redis 缓存
时间: 2023-08-23 15:07:33 浏览: 206
Flask Redis缓存是一种在Flask应用中使用Redis作为缓存存储的方式。引用\[1\]中提到了缓存穿透问题,即查询一个一定不存在的数据,导致每次请求都要到存储层去查询,失去了缓存的意义。为了解决这个问题,可以采用二级缓存的方式,即L1缓存和L2缓存。请求优先从L1缓存获取数据,如果未命中,则加锁,保证只有一个线程去数据库中读取数据然后再更新到L1和L2中。其他线程依然在L2缓存获取数据,这样可以避免两个Redis都被击穿。\[2\]
在Flask Redis缓存中,可以使用一些方法来清除缓存。例如,可以使用`cache.delete()`方法传入对应的键来删除cached类型缓存,使用`cache.delete_memoize()`方法传入对应的键来删除memoize类型缓存,还可以使用`cache.clear()`方法来清空所有缓存。通常不建议使用`cache.clear()`方法,因为它会清空所有缓存,而是建议根据需要选择性地删除特定的缓存。\[3\]
所以,Flask Redis缓存是一种使用Redis作为缓存存储的方式,可以通过采用二级缓存来解决缓存穿透问题,并且可以使用`cache.delete()`、`cache.delete_memoize()`和`cache.clear()`等方法来清除缓存。
#### 引用[.reference_title]
- *1* *2* [秒杀系统(三)Redis缓存和分布式锁](https://blog.csdn.net/ohwang/article/details/122953122)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
- *3* [Flask-Caching使用redis缓存后端加速页面重载](https://blog.csdn.net/weixin_43863487/article/details/124117913)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
阅读全文