Loading
0

nginx的proxy_cache缓存相关配置

本文主要介绍nginx的proxy_cache缓存的配置及nginx平滑升级。
nginx的proxy_cache缓存用于反向代理时,对后端内容资源服务器进行缓存,缓存静态资源。

一、proxy_cache相关指令说明
1.proxy_cache指令
语法:proxy_cache zone_name;
默认值:none
使用配置段:http,server,location
该指令用于设置哪个缓存区将被使用,zone_name的值为proxy_cache_path指令创建的缓存区名称
2.proxy_cache_path指令
语法:proxy_cache_path  path [levels=number] keys_zone=zone_name:zone_size [inactive=time] [max_size=size];
默认值:none
使用配置段:http
该指令用于设置缓存文件的存放路径
proxy_cache_path /usr/local/nginx-1.6/proxy_cache  levels=1:2  keys_zone=cache_one:100m inactive=2d  max_size=2g;
levels指定该缓存空间有两层hash目录,第一层目录为1个字母,第二层为2个字母
keys_zone参数设置这个缓存区的名称和内存缓存空间大小
inactive参数设置数据多长时间没有被访问将删除
max_size参数设置硬盘缓存空间大小
3.proxy_cache_methods指令
语法:proxy_cache_methods  [GET HEAD POST];
默认值:proxy_cache_methods  GET HEAD POST;
使用配置段:http,server,location
该指令用于设置缓存哪些HTTP方法
4.proxy_cache_min_uses指令
语法:proxy_cache_min_uses number;
默认值:proxy_cache_min_uses 1;
使用配置段:http,server,location
该指令用于设置缓存的最小使用次数
5.proxy_cache_valid指令
语法:proxy_cache_valid
默认值:none
使用配置段:http,server,location
该指令用于对不同返回状态码的URL设置不同的缓存时间
例如,设置200、302状态的URL缓存10分钟,404状态的URL缓存1分钟,不指定状态码表示200、301、302
proxy_cache_valid  200  302   10m;
proxy_cache_valid  404    1m;
proxy_cache_valid  5m;
proxy_cache_valid  any  1m;  其余没有定义的状态码,
6.proxy_cache_key指令
语法:proxy_cache_key  line;
默认值:none
使用配置段:http,server,location
该指令用来设置web缓存的key值,nginx根据key值MD5哈希存储缓存,根据域名、请求路径等变量
proxy_cache_key  $host$uri$is_args$args;

二、实验环境
平台:centos6.6_x86_64
nginx主机:192.168.115.22
tomcat主机:192.168.115.23
nginx版本:1.3.14
手动清除缓存需要增加模块ngx_cache_purge,因此需要重新编译

三、安装配置
1.编译nginx
# ./configure  --prefix=/usr/local/nginx --user=nobody --group=nobody --with-select_module --with-poll_module --with-file-aio --with-http_ssl_module --with-http_realip_module --with-http_gzip_static_module --with-http_secure_link_module --with-http_sub_module --with-http_stub_status_module --with-http_perl_module --add-module=/usr/local/src/nginx-http-concat/ --add-module=/usr/local/src/nginx-sticky-module-1.1 --add-module=/usr/local/src/nginx_tcp_proxy_module-master --add-module=/usr/local/src/ngx_cache_purge-2.3
# make
这里不执行install,直接复制编译好的二进制文件替换原有的二进制文件,注意需要备份文件
2.平滑升级nginx
# mv /usr/local/nginx/sbin/nginx  /usr/local/nginx/sbin/nginx.old
# cp -p /root/soft/nginx/nginx-1.3.14/objs/nginx   /usr/local/nginx/sbin/
执行以下命令,nginx新旧进程一起工作
# kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`

关闭旧的工作进程,此时旧的主进程还存在,可以选择使用新版本是恢复到旧版本
# kill -WINCH `cat /usr/local/nginx/logs/nginx.pid.oldbin`

如果想恢复到旧版本,执行以下命令,将重新生成旧的工作进程
# kill -HUP `cat /usr/local/nginx/logs/nginx.pid.oldbin`
使用新版本,就关闭旧版本的主进程
# kill -QUIT `cat /usr/local/nginx/logs/nginx.pid.oldbin`
至此nginx升级成功
3.配置nginx的proxy缓存
在nginx主配置文件nginx.conf中的http段添加如下两行
proxy_temp_path /usr/local/nginx/proxy_temp;
proxy_cache_path /usr/local/nginx/proxy_cache levels=1:2 keys_zone=cache_one:100m inactive=1d max_size=1g;
在/usr/local/nginx/conf/extra目录下编辑web.conf配置文件
server {
listen      8800;
server_name hnr.test.com;
index index.html;
access_log logs/hnr.test.com access_log;

location / {
root   html;
index index.html index.htm;
proxy_set_header Host   $host:$server_port;

分页阅读: 1 2
【声明】:8090安全小组门户(https://www.8090-sec.com)登载此文出于传递更多信息之目的,并不代表本站赞同其观点和对其真实性负责,仅适于网络安全技术爱好者学习研究使用,学习中请遵循国家相关法律法规。如有问题请联系我们:邮箱hack@ddos.kim,我们会在最短的时间内进行处理。