一道腾讯的面试题:如何避免 CDN 为 PC 端缓存移动端页面
2020/7/14 11:08:48
本文主要是介绍一道腾讯的面试题:如何避免 CDN 为 PC 端缓存移动端页面,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
❝本文收录于 GitHub 日问: DailyQuestion,内含大厂内推机会、面经大全及若干面试题,每天学习五分钟,一年进入大厂中。
❞
大厂面经大全 大厂内推
如果 PC 端和移动端是一套代码则不会出现这个问题。「这个问题出现在 PC 端和移动端是两套代码,却共用一个域名。」
使用 nginx
配置如下,根据 UA 判断是否移动端,而走不同的逻辑 (判断UA是否移动端容易出问题)
location / { // 默认 PC 端 root /usr/local/website/web; # 判断 UA,访问移动端 if ( $http_user_agent ~* "(Android|webOS|iPhone|iPad|BlackBerry)" ){ root /usr/local/website/mobile; } index index.html index.htm; } 复制代码
解决方案通常使用 Vary
响应头,来控制 CDN 对不同请求头的缓存。
「此处可以使用 Vary: User-Agent
,代表如果 User-Agent 不一样,则重新发起请求,而非从缓存中读取页面」
Vary: User-Agent 复制代码
当然,User-Agent
实在过多,此时缓存失效就会过多。
简答
使用 Vary: User-Agent
,根据 UA 进行缓存。
Vary: User-Agent 复制代码
但最好不要出现这种情况,PC 端和移动端如果是两套代码,建议用两个域名,理由如下
nginx
判断是否移动端容易出错对缓存不友好
更多面试
【字节-视频架构组-前端】头条架构组招人了内含自测题 【美团】什么是防抖和节流,他们的应用场景有哪些 【美团】如何获取一个进程的内存并监控
关注我
❝本文收录于 GitHub 日问: DailyQuestion,内含大厂内推机会、面经大全及若干面试题,每天学习五分钟,一年进入大厂中。
❞
大厂面经大全 大厂内推
我是山月,正致力于「每天用五分钟能够看完的简短答案回答一个大厂高频面试题」。可扫码关注,或者公众号中回复微信与我交流。
本文使用 mdnice 排版
这篇关于一道腾讯的面试题:如何避免 CDN 为 PC 端缓存移动端页面的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享