当前位置: > Linux服务器 > nginx >

nginx 反向代理,动静态请求分离,proxy_cache缓存及缓存清除

时间:2016-09-10 14:01来源:linux.it.net.cn 作者:IT
一,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; 
 
}  


(责任编辑:IT)
------分隔线----------------------------
栏目列表
推荐内容