宝塔面板大家都比较熟悉,非常简单实用,还可以利用nginx反代当自建CDN节点使用,但我在使用宝塔面板默认的Nginx缓存配置时遇到了一个问题:

  • 开启反向代理缓存后不能正常登陆typecho后台;

针对于这个问题,现在分享一下我的解决方法。

原因分析

宝塔官方是默认对JS/CSS等静态文件缓存,但是如果设置了typecho伪静态的话,那将会对页面也缓存进去。比如设置某个页面伪静态后地址为:https://www.91linux.org/91.html ,那么该页面就被缓存了,因此就会导致不能正常登陆typecho。因为缓存的页面默认是没有登录的状态。

解决方法:

话不多说,直接分享出我的nginx配置代码,供大家参考,这里我们登录反向代理的宝塔面板,找到对应的网站,依次点击反向代理->配置文件

#PROXY-START/
location ~* \.(php|jsp|cgi|asp|aspx)$
{
    proxy_pass http://www.91linux.org;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header REMOTE-HOST $remote_addr;
}
location /
{
    #缓存媒体文件
    location ~* .jpg|.png|.gif|.jpeg|.ttf|.webp|.woff|.woff2|.ico|.css|.js|.html$
    {
    proxy_pass http://www.91linux.org;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header REMOTE-HOST $remote_addr;
    proxy_ignore_headers Set-Cookie Cache-Control expires;
    proxy_cache cache_one;
    proxy_cache_key $host$uri$is_args$args;
    proxy_cache_valid 200 304 301 302 360m;
    expires 12h;
    }
    
    proxy_pass http://www.91linux.org;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header REMOTE-HOST $remote_addr;
    
    add_header X-Cache $upstream_cache_status;
    #Set Nginx Cache
    proxy_ignore_headers Set-Cookie Cache-Control expires;
    add_header Cache-Control no-cache;
    expires 12h;
}

#PROXY-END/

针对以上代码的说明

因为宝塔里的反向代理文件默认是对静态文件全局缓存,我们采用针对性缓存的方式。

比如不希望缓存html,缓存的话容易出现typecho登陆后还是显示没有登陆的问题。那么将以上代码的html部分去掉就可以解决这个问题了。

Last modification:March 23, 2021
如果觉得我的文章对你有用,请随意赞赏