项目里边更换了同名的图片地址 / 图片没有及时更新 / 什么原因

一、问题分析

1.1、分析一 浏览器缓存

项目里边更换了同名的图片地址,图片没有及时更新

可能是浏览器缓存的原因,浏览器会将之前访问过的文件缓存下来,下次访问同名的文件时会先从缓存中读取。
如果相同的图片地址没有发生变化,浏览器就会直接使用缓存中的图片,而不是重新请求服务器。这就导致了同名图片地址更换后,页面上显示的图片没有及时更新。

<img src="image.jpg?v=123456">

每次加载时随机生成一个不重复的参数,这样浏览器就会认为这是一个新的地址,不会从缓存中读取,而是重新请求服务器下载新的图片。

1.2、分析二 CDN缓存

项目里边更换了同名的图片地址,图片没有及时更新

如果你的图片是通过CDN分发的,那么清除浏览器缓存可能还不够,因为CDN也会有一定的缓存时间。
当你更换同名的图片地址后,CDN上的缓存并不会立即失效,而是需要等待一定时间后才会刷新。因此,你需要清除CDN缓存来解决同名图片地址更换后无法及时更新的问题。

不同的CDN提供商具体的清除缓存方法可能会有所不同。大多数CDN提供商都提供了很方便的缓存刷新工具,你只需要输入要刷新的URL或者目录,然后点击刷新按钮即可。一般来说,CDN刷新需要一定的时间来生效,具体时间取决于CDN提供商的刷新策略和缓存时间。

1.3、分析三 CDN缓存

有些用户请求到的图片是新的,有些用户请求到的是旧的,什么原因呢

这种情况很可能是因为CDN缓存没有完全刷新导致的。
当你更换同名的图片地址后,CDN上的缓存并不会立即失效,而是需要等待一定时间后才会刷新。在这个过程中,有些用户可能会请求到旧的缓存图片,有些用户则会请求到新的图片。

为了解决这个问题,你需要通过清除CDN缓存来确保所有用户都能够请求到最新的图片。不同CDN提供商具体的清除缓存方法可能会有所不同,但基本都提供了缓存刷新工具,你可以输入要刷新的URL或者目录,然后点击刷新按钮来清空缓存。请注意,CDN刷新需要一定的时间来生效,具体时间取决于CDN提供商的刷新策略和缓存时间。

1.4、分析四 浏览器缓存和CDN缓存的交互作用

同一个用户,有时候看到新的有时候看到旧的,什么原因呢

如果同一个用户在不同的时间请求同一个图片,有时候看到新的有时候看到旧的,可能是因为浏览器缓存和CDN缓存的交互作用。

浏览器在请求图片时,会先检查自己的缓存是否有与该图片对应的缓存,如果有,就直接使用缓存,不会再向服务器请求新的图片。而CDN缓存的更新时间可能比较长,所以在浏览器缓存没有失效之前,如果CDN缓存中还是旧的图片,用户就会看到旧的图片。

解决这个问题的方法就是清除浏览器缓存。如果你想保证用户能够看到最新的图片,可以在更换图片地址后,附加一个随机数或者时间戳作为图片地址的一部分,这样可以避免浏览器和CDN缓存的影响,强制让浏览器重新请求新的图片。

1.5、分析五 访问CDN的节点

同一个用户,有时候看到新的有时候看到旧的,什么原因呢

访问的CDN节点可能会影响用户看到的内容是否是新的或旧的。
CDN是通过缓存内容来提高网站访问速度的技术,它会根据用户的位置,选择最近的CDN节点来提供内容。
如果一个CDN节点缓存了旧的内容,那么用户可能会在其访问时看到旧的内容,而其他缓存了新内容的CDN节点则可以提供新的内容给用户。
因此,访问的CDN节点会对用户看到的内容是否是新的或旧的起到一定的影响。

二、解决问题

2.1、方法一

可以在更换图片地址就可以了,cdn缓存,cdn洪流

<img src="image1.jpg">

2.2、方法二 

<img src="image.jpg?v=123456">

2.3、方法三

可以使用强缓存和协商缓存的机制,来控制浏览器缓存的有效期和更新方式。 

2.4、方法四

清除CDN缓存

2.5、方法五

不着急的话,可以等一等~

三、过程记录

记录一、使用强缓存和协商缓存的机制,如何来控制浏览器缓存的有效期和更新方式

强缓存和协商缓存是控制浏览器缓存的有效期和更新方式的两种机制。

强缓存

强缓存是通过在响应头中设置Cache-Control和Expires字段来实现的。在服务器端设置响应头的时候,可以通过设置Cache-Control和Expires字段来控制浏览器缓存的有效期和更新方式。如果设置了Cache-Control和Expires字段,客户端在请求资源时,会首先通过判断这两个字段来决定是否使用缓存。

Expires字段指定了过期时间,过期时间是一个具体的时间点。例如:Expires: Wed, 21 Oct 2023 07:28:00 GMT。这个时间点是服务器端的时间,如果当前时间在过期时间之前,浏览器就会使用缓存,否则就会请求服务器。

Cache-Control字段是HTTP/1.1引入的,可以设置多个参数来控制缓存的行为。其中比较重要的有:

max-age:指定缓存的最大有效时间,单位为秒。例如:Cache-Control: max-age=3600表示缓存1小时,如果在这个时间内再次请求资源,浏览器就会使用缓存。public:指明响应可以被缓存,包括客户端缓存和代理服务器缓存。private:指明响应只能被客户端缓存,不能被代理服务器缓存。

协商缓存

协商缓存是通过在响应头中设置Last-Modified和ETag字段来实现的。在服务器端设置响应头的时候,可以通过设置Last-Modified和ETag字段来控制浏览器缓存的有效期和更新方式。如果设置了Last-Modified和ETag字段,客户端在请求资源时,会先发送一个请求到服务器,服务器会将这个请求中的If-Modified-Since(Last-Modified的值)和If-None-Match(ETag的值)字段与服务器中的资源进行比对,如果相同,则说明资源没有更新,可以使用缓存;否则说明资源已被更新,服务器会重新返回资源内容,并在响应头中设置新的Last-Modified和ETag字段。

强缓存和协商缓存可以通过设置不同的缓存头来控制浏览器缓存的有效期和更新方式,具体的设置可以根据实际应用场景进行调整。

记录二、理解CDN洪流

CDN洪流是指CDN(内容分发网络)服务器在一段时间内收到的大量请求。一些常见的解决方法包括:

1.增加CDN服务器数量:增加CDN服务器数量可以分担流量负载,提高响应速度和稳定性。

2.优化缓存:优化CDN缓存可以减少服务器请求,并降低服务器负载和响应时间。

3.使用负载均衡:使用负载均衡器可以将请求分配到不同的CDN服务器上,以便更好地处理CDN洪流。

4.限流:通过限制每秒请求的数量,可以减少CDN洪流的影响,并保护CDN服务器免受过载攻击。

5.使用CDN厂商提供的特殊解决方案:一些CDN厂商提供了特殊的解决方案,包括自适应调度器、预热、动态防御等,以帮助企业解决CDN洪流等问题。

四、欢迎交流指正

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/169678.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【刷题宝典NO.4】

目录 公交站间的距离 生命游戏 公交站间的距离 https://leetcode.cn/problems/distance-between-bus-stops/ 环形公交路线上有 n 个站&#xff0c;按次序从 0 到 n - 1 进行编号。我们已知每一对相邻公交站之间的距离&#xff0c;distance[i] 表示编号为 i 的车站和编号为 …

Axios笔记

目录 一、安装Axios 二、发送请求 &#xff08;一&#xff09;Get请求 &#xff08;二&#xff09;Post请求 1. 第一种方式 2. 第二种方式 三、拦截器 &#xff08;一&#xff09;请求前拦截器 &#xff08;二&#xff09;应答拦截器 四、封装 一、安装Axios -g 全局…

程序员职场可能遇到的问题总结!

在职场中&#xff0c;你是否遇到过这样的领导或同事&#xff0c;他可能是自恋狂&#xff0c;自吹自擂自我标榜&#xff1b;可能是团队合作的绊脚石&#xff0c;对团队合作态度消极并频繁拖后腿&#xff1b;可能是抱怨专家&#xff0c;满满负能量&#xff1b;可能是完美主义者&a…

二十一、数组(6)

本章概要 数组排序Arrays.sort的使用并行排序binarySearch二分查找parallelPrefix并行前缀 数组排序 根据对象的实际类型执行比较排序。一种方法是为不同的类型编写对应的排序方法&#xff0c;但是这样的代码不能复用。 编程设计的一个主要目标是“将易变的元素与稳定的元素…

win11渗透武器库,囊括所有渗透工具

开箱即用&#xff0c;最全的武器库&#xff0c;且都是2023年11月最新版&#xff0c;后续自己还可以再添加&#xff0c;下载地址&#xff1a;https://download.csdn.net/download/weixin_59679023/88565739 服务连接 信息收集工具 端口扫描 代理抓包 漏洞扫描 指纹识别 webshel…

【C语法学习】28 - 字符测试函数

文章目录 1 isalnum()函数2 isalpha()函数3 islower()函数4 isupper()函数5 isdigit()函数6 isxdigit()函数7 iscntrl()函数8 isgraph()函数9 isspace()函数10 isblank()函数11 isprint()函数12 ispunct()函数13 tolower()函数14 toupper()函数 1 isalnum()函数 isalnum()函数…

SpringBoot——》关联映射

推荐链接&#xff1a; 总结——》【Java】 总结——》【Mysql】 总结——》【Redis】 总结——》【Kafka】 总结——》【Spring】 总结——》【SpringBoot】 总结——》【MyBatis、MyBatis-Plus】 总结——》【Linux】 总结——》【MongoD…

移动机器人路径规划(七)--- 基于MDP的路径规划MDP-Based Planning

目录 1 什么是MDP-Based Planning 2 worst-case analysis for nondeterministic model 3 Expected Cost Planning 4 Real Time Dynamic Programming&#xff08;RTDP&#xff09; 1 什么是MDP-Based Planning 之前我们从起点到终点存在很多可执行路径&#xff0c;我们可以…

Can‘t find libdevice directory ${CUDA_DIR}/nvvm/libdevice

win10 Running deepxde 的时候出现问题&#xff1a; cuda-nvcc 安装后解决了。 # Install NVCC conda install -c nvidia cuda-nvcc11.3.58 -y # Configure the XLA cuda directory mkdir -p $CONDA_PREFIX/etc/conda/activate.d printf export LD_LIBRARY_PATH$LD_LIBRARY_P…

Python实现一箭穿心

文章目录 &#x1f384;效果&#x1f3f3;️‍&#x1f308;Turtle模块&#x1f339;代码&#x1f33a;代码讲解 &#x1f384;效果 &#x1f3f3;️‍&#x1f308;Turtle模块 Turtle是一个绘图工具&#xff0c;是Python标准库中的一个模块。它提供了一种简单而直观的方式来创…

【C++】内存管理(new与delete)

&#x1f440;樊梓慕&#xff1a;个人主页 &#x1f3a5;个人专栏&#xff1a;《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》 &#x1f31d;每一个不曾起舞的日子&#xff0c;都是对生命的辜负 前言 本篇文章我们一起来学习C的内存管理方式&…

最新yolov8环境搭建、推理训练一站式超详细教学

1、获取yolov8源码 访问yolov8_github官网&#xff0c;网络不稳定时可能需要加速器。yolov8源码地址 获取方式&#xff1a;直接下载或者git工具克隆 我使用git操作进行演示&#xff0c;复制github上的地址(需提前关闭加速器)。 git clone https://github.com/ultralytics/ul…

【QML】Qt设置USB免驱相机曝光时间(Linux系统)UVC

1. 问题 使用QML的Camera组件创建相机。需要配置曝光时间&#xff0c;使用CameraExposure中的exposureCompensation&#xff0c;exposureMode配置无效果&#xff0c;原因可能是不支持USB相机。 有两种方法经测试有效果&#xff1a; 命令行调用v4l2-ctl命令的方法&#xff0c…

【XSLVGL2.0】如何做全局键功能和键值映射

XSLVGL2.0 开发手册 【XSLVGL2.0】如何做全局键功能和键值映射 1、概述1、概述 项目常见需要配置一个按键,并要求短按此按键回到首页, 长按此按键进行关机。 XSLVGL2.0在输入设备对接接口中,有一个回调,在此回调中可以直接收到输入设备上报的所有按键事件。 一般这个功能…

UI自动化(selenium+python)之元素定位的三种等待方式!

前言 在UI自动化过程中&#xff0c;常遇到元素未找到&#xff0c;代码报错的情况。这种情况下&#xff0c;需要用等待wait。 在selenium中可以用到三种等待方式即sleep,implicitly_wait,WebDriverWait 一、固定等待(sleep) 导入time模块&#xff0c;设定固定的等待时间 缺…

计数问题+约瑟夫问题(map)

目录 一、计数问题 二、约瑟夫问题 一、计数问题 #include<iostream> #include<map> using namespace std; int main() {int n,x;cin>>n>>x;map<int,int>m;for(int i1;i<n;i){if(i>1 && i<10){m[i];}else{int temp i;while (…

解决github无法访问的办法

方法/步骤 1.问题描述&#xff1a;能联网但不能访问github.com 2.找到hosts文件。地址&#xff1a;C:\Windows\System32\drivers\etc &#xff08;一般是在这的&#xff09; 3.不要直接在这修改hosts文件&#xff0c;需要将hosts文件复制粘贴到桌面&#xff08;或其它地方自…

【仿写实现move函数】

仿写实现move函数 一、值的类型 1.左值 描述&#xff1a;能够取地址的值成为左值 int a 10; const int b 15; int *pa &a; const int *pb &b;2.纯右值 描述&#xff1a;赤裸裸的字面值 eg(false , 3 , 12.23等) int a 13; int *p &a; //取a的地址 int …

在线音频视频剪辑网站推荐

123apps: Online MP3 Cutter - Cut Songs, Make Ringtones

Datax安装部署及读取MYSQL写入HDFS

一.DataX简介 1.DataX概述 DataX 是阿里巴巴开源的一个异构数据源离线同步工具&#xff0c;致力于实现包括关系型数据库(MySQL、Oracle等)、HDFS、Hive、ODPS、HBase、FTP等各种异构数据源之间稳定高效的数据同步功能。 源码地址&#xff1a;https://github.com/alibaba/Data…