nginx 反向代理,动静态请求分离,proxy_cache缓存及缓存清除
发布日期:2021-06-30 19:22:26 浏览次数:3 分类:技术文章

本文共 8683 字,大约阅读时间需要 28 分钟。

一,nginx反向代理配置

     #tomcat

 

显然就是用户访问www.wolfdream.com(需要设置本地localhost,将www.wolfdream.com指向nginx所在IP)的时候(或将www.wolfdream.com直接写在nginx所在的IP地址),将请求转到到后台的tomcat服务器,即127.0.0.1:8080,并将请求到的数据转发给client

二,动静态请求相分离

   神马意思?图片,JS,HTML等静态的东西去访问一台专门的服务器,而动态的请求去访问另一台服务器。就这么简单,上例子:

 

server {         listen           
192.168
.
154.128
:
80
;
server_name image
.
wolfdream
.
com
;
index index
.
html
;
#
proxy_pass http:
//
tomcat_server
;
#
charset koi8-r
;
#
access_log logs
/
host
.
access
.
log main
;
location
/
{ root html
;
#
index index
.
html index
.
htm
;
proxy_redirect
off
;
proxy_set_header Host
$
host
;
proxy_set_header X-Real-IP
$
remote_addr
;
proxy_set_header X-Forwarded-
For
$
proxy_add_x_forwarded_for
;
} location ~
.
*
/.(
gif|jpg|jpeg|png|bmp|swf
)$
{ valid_referers none blocked
192.168
.
154.128
192.168
.
154.1
;
if
($
invalid_referer
)
{ rewrite ^
/
403
.
jpg
break
;
}
if
(
!-f
$
request_filename
)
{ rewrite ^
/
404
.
jpg last
;
} expires 30d
;
}
#
error_page
404
/
404
.
html
;
#
redirect server error pages to the static page
/
50x
.
html
#
error_page
500
502
503
504
/
50x
.
html
;
location
=
/
404
.
jpg { root html
;
} } tomcat upstream tomcat_server{ server
127.0
.
0.1
:
8080
;
} server{ listen
192.168
.
154.128
;
server_name www
.
wolfdream
.
com
;
location
/
{ proxy_redirect
off
;
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_pass http:
//
tomcat_server
;
} }

 

上面这种方式是通过设定不同的域名,可不可以在同一个域名中,通过判断后缀来将动态与静态请求相分离呢?

 

#    
tomcat upstream tomcat_server{ server
127.0
.
0.1
:
8080
;
} server{ listen
192.168
.
154.128
;
server_name www
.
wolf
.
com
;
location ~
.
*
/.(
gif|jpg|jpeg|png|bmp|swf
)$
{ root html
;
} location ~
.
*
/.(
jsp|
do
)$
{ proxy_redirect
off
;
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_pass http:
//
tomcat_server
;
}

 

OK!同一个域名,根据后缀不同,请求不同的服务,实现动态静态请求相分离。仔细想一想,如果又出现了一种静态的文件,比如*.abc ,那难道又去修改那个配制文件吗?显然不太合理,所以可以考虑将所有的表态文件放在同一个根目录下面,比如/static那么可以将上面的静态页面请求修改一下:

 

ocation      
/
static { root html
/
static
;
}

 

咦这样是不是就好一些了,而且文件的存放也比较有规范了。

三,nginx缓存应用

nginx具有web缓存服务,proxy_cache,但是有一个问题就是,proxy_cache不能清除指定的URL缓存,只能设置URL过期时间,但是有问题,有人就会很快解决问题,nginx第三方模块ngx_cache_purge能清除指定URL。

  nginx安装时需要将ngx_cache_purege加载进去。

 

./    
configure --user
=
www --group
=
www --add-module
=/
root
/
dxm
/
nginx
/
ngx_cache_purge-
1.2

 

其中,/root/dxm/nginx/ngx_cache_purge-1.2为ngx_cache_purge解压路径(附件中提供ngx_cache_purge tar包下载)

现在来一段实例,实现图片缓存:

   话说proxy_tem_path,与proxy_cache_path必须在同一个分区之下!

 

 

upstream tomcat_server{      server     
127.0
.
0.1
:
8080
;
} server{ listen
192.168
.
154.128
;
server_name www
.
wolf
.
com
;
location ~
.
*
/.(
gif|jpg|jpeg|png|bmp|swf
)$
{ proxy_cache cache_one
;
proxy_cache_methods GET HEAD POST
;
proxy_cache_min_uses
1
;
proxy_cache_valid
200
302
10m
;
proxy_cache_valid
404
1m
;
proxy_cache_valid any 1m
;
proxy_cache_key
"
$host:$server_port$uri$is_args$args
"
;
proxy_redirect
off
;
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_pass http:
//
tomcat_server
;
} location ~
.
*
/.(
jsp
)$
{ proxy_redirect
off
;
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_pass http:
//
tomcat_server
;
} location ~
/
purge
(/.
*
)
{ allow
192.168
.
154.128
;
allow
192.168
.
154.1
;
deny all
;
proxy_cache_purge cache_one
$
host:
$
server_port
$
1
$
is_args
$
args
;
}

 

恩,静态页面缓存,动态请求不缓存!

大家看一下最后一段的那个purege配置,很显然,表示哪些IP可以手动清除指定的URL

比如,www.wolfdraem.cn/1.jpg可以访问到我的图片,那么用www.wolfdream.cn/purge/1.jpg  就可以清除图片缓存了。

proxy_temp_path     
/
usr
/
local
/
nginx
/
proxy_temp
;
proxy_cache_path
/
usr
/
local
/
nginx
/
proxy_cache_path levels
=
1
:
2
keys_zone
=
cache_one:200m inactive
=
1d max_size
=
1g
;

upstream tomcat_server{  server     
127.0
.
0.1
:
8080
;
} erver{ listen
80
;
server_name www
.
wolfdream
.
com
;
location
/
{ proxy_redirect
off
;
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_pass http:
//
tomcat_server
;
}

转载地址:https://linuxstyle.blog.csdn.net/article/details/6573825 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:nginx 的proxy_cache才是王道
下一篇:使用Nginx的proxy_cache缓存功能取代Squid

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2024年05月03日 04时33分02秒