打造高性能nginx缓存服务器

 

一、nginx缓存

    Nginx从0.7.48版本开始,支持了类似Squid的缓存功能。这个缓存是把URL及相关组合当作Key,用md5编码哈希后保存在硬盘上,所以它可以支持任意URL链接,同时也支持404/301/302这样的非200状态码。虽然目前官方的Nginx Web缓存服务只能为指定URL或状态码设置过期时间,不支持类似Squid的PURGE指令,手动清除指定缓存页面,但是,通过一个第三方的Nginx模块,可以清除指定URL的缓存。 

 

二、如何实现nginx缓存

 

1)实验图

 

2)安装包

nginx-1.5.0.tar.gz

wget http://nginx.org/download/nginx-1.5.0.tar.gz

ngx_cache_purge-2.1.tar.gz

wget http://labs.frickle.com/files/ngx_cache_purge-2.1.tar.gz

 

3)安装前准备:

在nginx服务器根目录下创建cache目录,用于挂在缓存盘或存放缓存数据,名字可以随便命名,我这里用的是将4块磁盘做raid5,挂在到/cache上面。

 

4)安装:

1 useradd-r www -s /sbin/nologin

2 tar-zvxf ngx_cache_purge-2.1.tar.gz 

3 tar-zvxf nginx-1.5.0.tar.gz

4 cdnginx-1.5.0

5 yum-y install pcre-* openssl-*

6 ./configure \

--prefix=/usr/local/nginx \

--user=www \

--group=www \

--with-http_stub_status_module \

--with-http_ssl_module \

--add-module=/usr/src/ngx_cache_purge-2.1

7 make

8 make install

/usr/local/nginx/sbin/nginx ##start nginx service

 

5)测试nginx:

   firefox http://localhost &

 

看到此测试页面说明你的nginx安装成功。

 

 

6) 配置nginx-cache

vim /usr/local/nginx/conf/nginx.conf

#usernobody;

worker_processes1;

events {

use epoll;

worker_connections 65535;

}

http {

includemime.types;

default_type application/octet-stream; 

sendfile on;

keepalive_timeout 65;

upstream web {

server 192.168.1.201;

server 192.168.1.202;

}

proxy_temp_path/cache/proxy_temp_dir; 

proxy_cache_path /cache/proxy_dir levels=1:2 keys_zone=cache0:200minactive=1d max_size=30g;

server {

listen80;

server_namelocalhost;

location / {

proxy_pass http://web;

proxy_next_upstream http_502 http_504 error timeout invalid_header;

proxy_cache cache0;

proxy_cache_valid 200 304 30m;

proxy_cache_valid any 1m;

proxy_cache_key $host$uri$is_args$args;

proxy_set_header Host$host;

proxy_set_header X-Forwarded-For $remote_addr;

expires 60m;

}

location ~/purge(/.*)

{

allow 127.0.0.1;

allow 192.168.1.0/24;

proxy_cache_purge cache0$host$1$is_args$args;

}

location ~*/.(php|jsp|cgi)?$

{

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $remote_addr;

proxy_pass http://web;

}

error_page500 502 503 504/50x.html;

location = /50x.html{

roothtml;

      }

    }

}

 

7)配置文件关键语句解释

proxy_temp_path/data0/proxy_temp_dir; 

##临时缓存目录

proxy_cache_path /data0/proxy_dir levels=1:2 keys_zone=cache0:200minactive=1d max_size=30g;

##定义缓存目录路径/data0/proxy_dir

##硬盘缓存中目录分为两级,第一级文件夹名字是1个字母,第二级文件夹名字是两个字母levels=1:2

##定义缓存区域名字(新建内存缓存区域为200M)keys_zone=cache0:200m

##缓存内容1天后自动到期清除inactive=1d

##在缓存硬盘上划分30G空间max_size=30g

##超过2M不缓存max_size=2m

## clean_time指定一分钟清理一次缓存clean_time=1m

proxy_next_upstream http_502 http_504 errortimeout invalid_header;

##如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。

proxy_cachecache0;

##启用上述创建的缓存区域cache0

proxy_cache_valid 200 304 30m;

##对返回状态200 304 缓存30分钟

proxy_cache_validany 1m;

##对其他状态码缓存10分钟

proxy_cache_key $host$uri$is_args$args;

##以域名、URI、参数组合成Web缓存的Key值,Nginx根据Key值哈希,存储缓存内容到二级缓存目录内。指令指定了包含在缓存中的缓存关键字。

proxy_set_header Host $host;

##修改客户GET请求头中的 HOST字段。在取源的时候保持客户端的请求字段没变。

proxy_set_header X-Forwarded-For $remote_addr;

##修改远端地址,保持在缓存服务器取源的时候,让源访问日志中能记录到是那个真正远端客户地址,否则默认都是认为是缓存服务器地址,这样源永远不知道到底是谁在访问它。

expires 60m;

##在服务器http响应头中加入过期时间为60分钟,启用客户端本地缓存。时间为60分。

location ~/purge(/.*)

{

allow 127.0.0.1;

allow 192.168.1.0/24;

proxy_cache_purge cache0$host$1$is_args$args;

}

#使用purge工具清除缓存URL

例如需要清除的URL为:

http://192.168.1.200/test.html

在浏览器中访问

http://192.168.1.200/purge/test.html就可以清除该URL的缓存。

通过访问控制定义允许那些机器可以使用purge清空URL,不是谁都能随便清空的。

location ~*/.(php|jsp|cgi)?$

{

proxy_set_header Host $host;

proxy_set_header X-Forwarded-For $remote_addr;

proxy_pass http://web;

}

不缓存动态页面

error_page500 502 503 504/50x.html;

location = /50x.html{

roothtml;

}

错误代码由本机提供页面

 

 

你可能感兴趣的:(linux,nginx,缓存,RHEL)