Nginx 缓存使用指南-简单

简介: Nginx 缓存使用指南-简单

 

## 重点部分

### http 模块增加

```text

   proxy_buffer_size 16k;

   proxy_buffers 4 32k;

   proxy_busy_buffers_size 96k;

   proxy_cache_path /tmp/cache levels=1:2 keys_zone=cache_one:100m inactive=1d max_size=10g;

   proxy_connect_timeout 10;

   proxy_read_timeout 180;

   proxy_send_timeout 5;

   proxy_temp_file_write_size 96k;

   proxy_temp_path /tmp/temp_dir;

```

### 匹配规则模块增加

* 正则匹配,缓存图片/js类型文件

 ```text

     location ~ .*\.(gif|jpg|png|css|js)(.*) {

                 proxy_pass http://127.0.0.1:8780;

                 proxy_redirect off;

                 proxy_set_header Host $host;

                 proxy_cache cache_one;

                 proxy_cache_valid 200 302 24h;

                 proxy_cache_valid 301 30d;

                 proxy_cache_valid any 5m;

                 rewrite ~/(.*)$ /$1 break;

                 expires 24h;

                 add_header zuiyu_say  "hey! Guys! Give me one to see";

     }

 ```

 

* 对url匹配

 ```text

 

     location /api/loadFileStream {

                 proxy_pass http://127.0.0.1:8780;

                 proxy_redirect off;

                 proxy_set_header Host $host;

                 proxy_cache cache_one;

                 proxy_cache_key $uri;

                 proxy_cache_valid 200 302 24h;

                 proxy_cache_valid 301 30d;

                 proxy_cache_valid any 5m;

                 expires 24h;

                 add_header zuiyu_say  "hey! Guys! Give me one to see";

     }

 ```

 

到此,缓存即配置完成,就可以测试 一下了

## 配置项解读

### http 模块

* proxy_buffer_size 缓冲区大小

* proxy_buffers 每个连接设置缓冲区的数量为number,每块缓冲区的大小为size

* proxy_busy_buffers_size 开启缓冲响应 的功能以后,在没有读到全部响应的情况下,写缓冲到达一定大小时,nginx一定会向客户端发送响应,直到缓冲小于此值

* proxy_cache_path 设置缓存的路径和其他参数。被缓存的数据如果有inactive参数,当前参数是1天,指定的时间未被访问,就会从缓存中移除

* proxy_connect_timeout 服务器连接超时时间

* proxy_read_timeout 连接成功后,等待后端服务器响应时间

* proxy_send_timeout 后端服务器数据回传时间

* proxy_temp_file_write_size 设置nginx每次写数据到临时文件的size大小限制

* proxy_temp_path 从后端服务器接受的临时文件存放路径

### 匹配规则模块

* proxy_pass nginx缓存拿不到资源向该地址转发请求,拿到获取的资源并进行缓存

* proxy_redirect 设置后端服务器Location响应头和Refresh响应头的替换文本

* proxy_set_header 允许重新定义发往后端服务器的请求头

* proxy_cache 指定用于页面缓存的共享内存,对应http层设置keys_zone

* proxy_cache_key 缓存的key 默认"$host$request_uri $cookie_user"; 可以使用下面nginx配置参数获取指定参数hash一个自定义的key

* proxy_cache_valid 对不同响应的状态码设置不同的缓存时间

* expires 缓存时间

* add_header 对服务器返回的响应头内容添加自定义返回数据,格式为 add_header key value

## Nginx 配置获取参数详解

```text

nginx 各参数翻译,作用

$arg_PARAMETER #这个变量包含GET请求中,如果有变量PARAMETER时的值。

$args #这个变量等于请求行中(GET请求)的参数,例如foo=123&bar=blahblah;

$binary_remote_addr #二进制的客户地址。

$body_bytes_sent #响应时送出的body字节数数量。即使连接中断,这个数据也是精确的。

$content_length #请求头中的Content-length字段。

$content_type #请求头中的Content-Type字段。

$cookie_COOKIE #cookie COOKIE变量的值

$document_root #当前请求在root指令中指定的值。

$document_uri #与$uri相同。

$host #请求主机头字段,否则为服务器名称。

$hostname #Set to the machine’s hostname as returned by gethostname

$http_HEADER

$is_args #如果有$args参数,这个变量等于”?”,否则等于”",空值。

$http_user_agent #客户端agent信息

$http_cookie #客户端cookie信息

$limit_rate #这个变量可以限制连接速率。

$query_string #与$args相同。

$request_body_file #客户端请求主体信息的临时文件名。

$request_method #客户端请求的动作,通常为GET或POST。

$remote_addr #客户端的IP地址。

$remote_port #客户端的端口。

$remote_user #已经经过Auth Basic Module验证的用户名。

$request_completion #如果请求结束,设置为OK. 当请求未结束或如果该请求不是请求链串的最后一个时,为空(Empty)。

$request_method #GET或POST

$request_filename #当前请求的文件路径,由root或alias指令与URI请求生成。

$request_uri #包含请求参数的原始URI,不包含主机名,如:”/foo/bar.php?arg=baz”。不能修改。

$scheme #HTTP方法(如http,https)。

$server_protocol #请求使用的协议,通常是HTTP/1.0或HTTP/1.1。

$server_addr #服务器地址,在完成一次系统调用后可以确定这个值。

$server_name #服务器名称。

$server_port #请求到达服务器的端口号。

$uri #不带请求参数的当前URI,$uri不包含主机名,如”/foo/bar.html”。该值有可能和$request_uri 不一致。$request_uri是浏览器发过来的值。该值是rewrite后的值。例如做了internal redirects后。

```


 

目录
相关文章
|
6月前
|
缓存 应用服务中间件 nginx
百度搜索:蓝易云【nginx反向代理缓存教程。】
现在,nginx已经配置了反向代理缓存。它将缓存后端服务器的响应,并在下次请求时直接提供缓存的响应,减轻后端服务器的负载并提高性能。
192 1
|
6月前
|
存储 缓存 Java
Nginx之Openresty缓存解读
Nginx之Openresty缓存解读
|
7月前
|
缓存 NoSQL 应用服务中间件
基于Nginx+Lua优化多级缓存架构
基于Nginx+Lua优化多级缓存架构
117 0
|
7月前
|
缓存 NoSQL 应用服务中间件
基于Redis和Nginx实现高并发缓存架构
基于Redis和Nginx实现高并发缓存架构
422 0
|
9月前
|
缓存 负载均衡 JavaScript
Nginx一网打尽:动静分离、压缩、缓存、黑白名单、跨域、高可用、性能优化...
Nginx一网打尽:动静分离、压缩、缓存、黑白名单、跨域、高可用、性能优化...
229 0
|
9月前
|
缓存 负载均衡 前端开发
Nginx+HAproxy+Keepaliaved缓存搭建
前端服务有大量的数据需要从后端获取,造成网络带宽的压力,同时也降低了服务性能。为了解决类似的问题, 可以在访问前端时,使用nginx缓存多次需要访问的数据
|
10月前
|
域名解析 缓存 负载均衡
记一次Nginx DNS缓存导致转发问题
记一次Nginx DNS缓存导致转发问题
11099 3
|
11月前
|
缓存 应用服务中间件 nginx
重识Nginx - 11 使用ngx_http_proxy_module的proxy_cache搭建一个具备缓存功能的反向代理服务
重识Nginx - 11 使用ngx_http_proxy_module的proxy_cache搭建一个具备缓存功能的反向代理服务
186 0
|
12月前
|
数据采集 缓存 网络协议
Nginx 一网打尽:动静分离、压缩、缓存、黑白名单、跨域、高可用、性能优化... ( 二)
Nginx 一网打尽:动静分离、压缩、缓存、黑白名单、跨域、高可用、性能优化.. .(二)
|
1月前
|
缓存 NoSQL 安全
【Redis】缓存穿透
【Redis】缓存穿透
30 0