【秒杀系统】查询性能优化技术之页面静态化

DNS用CNAME解析到源站

在这里插入图片描述

整个的一个商品详情页,先加载静态资源后通过 ajax 请求获取商品详情页内容渲染的方式,任何一步没做到位,都会拖累整个系统 tps/qps 的一个响应
在这里插入图片描述
现在的静态请求直接是打到我们的 Nginx 的 resources 的目录,现在将 resources 的地址重定向到阿里云的 CDN 内容分发网络,在获取静态资源内容先通过 CDN,CDN 没有在回源到阿里云源站(源站可以理解为本地静态资源文件),一边返回静态资源文件一边缓存起来,以便用户下一次访问时可以不做回源的操作

阿里云 CDN 配置

在这里插入图片描述
解析CNAME参考地址:https://help.aliyun.com/document_detail/98297.html
在这里插入图片描述
域名管理添加记录
在这里插入图片描述
这样商品详情页就会放到对应 CDN 网络上面去,当用户访问DNS服务器时,就会把对应请求发送到 CNAME 地址
在这里插入图片描述
阿里云服务器会解析出来用户的 IP 是属于哪里,阿里云就会返回一个就近的 CDN 节点,让这个用户去访问这个 CDN 节点对应的 IP 地址,然后 CDN 节点判断自己缓没缓存这个静态资源文件,如果有直接返回没有就回源到配置的 Nginx 服务器上面

一般情况下静态资源 Nginx 和 动态资源 Nginx 是分开部署的,为了简单就部署到了同一个 Nginx 上面,现在架构图如下所示

在这里插入图片描述

回源缓存设置

在这里插入图片描述
cache control 响应头

private:客户端可以缓存
public:客户端和代理服务器都可以缓存
max-age=xxx:缓存的内容将在xxx秒后失效
no-cache:强制向服务端再验证一次
no-store:不缓存请求的任何返回内容
在这里插入图片描述

有效性判断

ETag:资源唯一标识
将请求资源的内容做一个 MD5 等操作生成一个 ETage 唯一标识,服务端在第一次返回内容时加上这个 ETage 唯一标识一起返回给浏览器,浏览器会存储下来,下一次请求时将 ETage 的值一起带到服务器上用来验证浏览器不是发送对应响应而是发送 http请求,服务端会将客户端发送过来的值和本地作比较,一致则返回304

If-None-Match :客户端发送的匹配Etag标识符
Last-modified :资源最后被修改的时间

If-Modified-Since :客户端发送的匹配资源最后修改时间的标识符

在这里插入图片描述
在这里插入图片描述

浏览器三种刷新方式

回车刷新或a链接:看cache-control对应的max-age是否仍然有效,有效则直接from cache ,若cache-control中为no-cache ,则进入缓存协商逻辑

F5刷新或command+ R刷新:去掉cache-control中的max-age或直接设置max-age为0 ,然后进入缓存协商逻辑

ctrl+ F5 或 commond +shift+ R 刷新:去掉cache-control和协商头,强制刷新

协商机制,比较Last-modified和ETag到服务端,若服务端判断没变化则304不返回数据,否则200返回数据

自定义缓存策略

可自定义目录过期时间
可自定义后缀名过期时间
可自定义对应权重
可通过界面或api强制cdn对应目录刷新(非保成功)

在这里插入图片描述

全页面静态化

定义:在服务端完成html , css 甚至 js 的 load 渲染成纯 html 文件后直接以静态资源的方式部署到 cdn 上

在这里插入图片描述

强推失效

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值