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