宝塔面板大家都比较熟悉,非常简单实用,还可以利用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部分去掉就可以解决这个问题了。