使用Redis做动态页面缓存,提高网页访问速度

目的

本关目的:实现使用Redis缓存网页。

相关知识

本文将教会你掌握:1SETEX命令,2hash()方法。

在动态生成网页的时候,通常会使用模板(template)来简化网页的生成,现在已经不再需要我们手写一整个页面。通常,一个网页包括头部,尾部,侧边栏,工具栏和内容域等部分组成,每个部分都会独立使用一个模板来编写。

尽管都是动态的生成网页了,但大多数网站的内容都不会经常变化(大的变化),大多数网页的内容也是在一定周期内保持不变,这些网页就不需要动态生成。

本关卡中,我们会通过缓存的方式避免生成这些页面,减少动态生成页面所花费的时间,降低服务器的负载,提高网页访问速度。

我们需要在请求被响应之前,通过一个缓存函数判断:

  • 尝试从缓存中取出该请求的响应页面并返回
  • 若上述缓存不存在(失效),则:
    • 响应该请求,生成页面
    • 缓存至 Redis,生存时间为10分钟
    • 将该页面返回

我们可以使用字符串键来存储缓存页面,所以你可以使用 GET 命令尝试取出缓存页面,但当我们想要缓存页面时,则应该使用 SETEX 命令,该命令和 SET 命令的区别是,它是一个原子性(atomic)操作,关联值和设置生存时间两个动作会在同一时间内 完成,所以它在 Redis 用作缓存时很常用。它的语法如下:

sql 复制代码
conn.setex(key, value, seconds)

其中:seconds 是键的生存时间,单位为秒。

我们将真实的请求响应简化一下,变为返回一个字符串 "content for http://xxx",这样我们整个缓存方法就是:

python 复制代码
def cache_request(request_url):
page_key = 'cache:' + str(hash(request_url))
content = conn.get(page_key)

if not content:
content = "content for " + request_url
conn.setex(page_key, content, 600)

return content

其中,我们使用了 hash() 方法将一个请求的 URL 地址通过哈希编码转化成为一个字符串,该字符串和 URL 一一对应,所以我们可以使用这个哈希值作为缓存的键。

相关推荐
用户8356290780517 小时前
Python 操作 PDF 附件:添加、查看与管理指南
后端·python
Databend9 小时前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
犯困蛋挞yy10 小时前
用Claude快速解决Redis代码报错反复无解的问题
redis
北域码匠13 小时前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
宇宙之一粟15 小时前
乐企版式文件生成平台
java·后端·python
学测绘的小杨1 天前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
小七-七牛开发者1 天前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
ClouGence2 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
zzzzzz3102 天前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐2 天前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python