歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> 關於Linux >> nginx 反向代理,動靜態請求分離,proxy

nginx 反向代理,動靜態請求分離,proxy

日期:2017/3/2 9:58:38   编辑:關於Linux

一,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;

}
Copyright © Linux教程網 All Rights Reserved