WebEnh

.net7 mvc jquery bootstrap json 学习中 第一次学PHP,正在研究中。自学进行时... ... 我的博客 https://enhweb.github.io/ 不错的皮肤:darkgreentrip,iMetro_HD
随笔 - 1079, 文章 - 1, 评论 - 75, 阅读 - 174万
  首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

记录一次由nginx配置引发出来的一系列的缓存问题

Posted on   WebEnh  阅读(207)  评论(0编辑  收藏  举报

问题描述:

在做一个企业微信的移动端项目时,每次修改代码后并且打包、部署完毕,再次打开页面总是会有上一次的缓存,一开始以为是cookie和webStorage缓存导致的,然后每次清除还是有缓存,后来把企业微信本身的缓存清除了之后再重进才有效果

问题推理:
如果每次打开是上一次的缓存,那可能就是index.html的根文件被缓存住了,因为index.html里面会加载所有css、js文件,当时打开network看了下,响应头里面并没有Cache-Control: no-store, no-cache的字段,那问题的原因肯定是出在这儿了,上线的相关的部署配置是放在nginx上的;因为公司走的都是统一的容器化部署,当时nginx的部署也可以定制化的;

原因定位:
根据上面的问题推理,找到了前端项目的相关nginx配置(default.conf ),代码如下:

复制代码
server {
    listen       80;
    server_name  localhost;
 
    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;
    root  /usr/share/nginx/html;
 
    location / {
        try_files $uri /index.html;
        index  index.html index.htm;
    }
 
    location ^~ /freight {
        try_files $uri /freight/index.html;
    }
 
    location ^~ /s3/ {
        # fix ios previewImage 加载失败
        proxy_set_header Accept "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9";
        proxy_pass xxxxxx;
    }
 
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
 
    location ~* .*\.(?:jpg|jpeg|gif|png|ico|cur|gz|svg|svgz|mp4|ogg|ogv|webm)$ {
        expires 7d;
        access_log off;
        add_header Cache-Control "public";
    }
 
    location ~* .*\.(?:js|css)$ {
        expires 7d;
        access_log off;
        add_header Cache-Control "public";
    }
 
    location ~* .*\.(?:htm|html)$ {
        add_header Cache-Control "no-store, no-cache";
        add_header Pragma "no-cache";
    }
}
 
复制代码

一眼扫过去,发现有针对html文件去除缓存的配置啊,如下:

 location ~* .*\.(?:htm|html)$ {
        add_header Cache-Control "no-store, no-cache";
        add_header Pragma "no-cache";
    }

那为什么network里面响应头里面没有携带“no-store, no-cache” 信息呢?经过一番摸索,问题其实是出在下面这个配置上了,因为项目代码存放的文件夹是freight

// 当匹配到该路径时,try_files的作用是会直接解析freight下面index.html文件,nginx就会终止往下查询了
location ^~ /freight {
    try_files $uri /freight/index.html;
}

那就需要把相关去除缓存的配置移动到location ^~ /freight这个匹配项里面去,如下所示:

复制代码
location ^~ /freight {
        try_files $uri /freight/index.html;
 
         if ($uri ~* .*\.(?:htm|html)$) {
            add_header Cache-Control "no-store, no-cache";
            add_header Pragma "no-cache";
        }
 
        if ($uri ~* .*\.(?:js|css|jpg|jpeg|gif|png|ico|cur|gz|ttf|woff|ico|svg|svgz|mp4|ogg|ogv|webm)$) {
            expires 7d;
            access_log off;
            add_header Cache-Control "public";
        }
        index  index.html index.htm;
    }
复制代码

最终问题得到解决了!

 

 




 

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2022-12-21 设置 ASP.NET Core Web API 中响应数据的格式 AddNewtonsoftJson 使用NewtonsoftJson替换掉默认的System.Text.Json序列化组件
2018-12-21 nginx 常见正则匹配符号表示
2018-12-21 Nginx if 条件判断
2016-12-21 【Bootstrap-插件使用】Jcrop+fileinput组合实现头像上传功能
2016-12-21 一个基于Microsoft Azure、ASP.NET Core和Docker的博客系统
2016-12-21 ASP.NET MVC 3 技术(九) 301永久重定向不带www域名到带www的域名
2016-12-21 ASP.NET MVC 3 网站优化总结(三)Specify Vary: Accept-Encoding header
点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

了解更多