传统的web项目,一般都将静态资源连同项目部署在容器中(如tomcat、jetty),但是有时需要把这些静态资源文件单独拿出来,ngnix这时可以来充当静态资源服务器的功能。
静态资源web服务
静态资源就是非服务器动态生成的文件,主要有:
静态资源服务场景-CDN
静态资源核心配置
1. 文件读取 sendfile
- sendfile 是一种高效传输文件的模式.
sendfile设置为on表示启动高效传输文件的模式。sendfile可以让Nginx在传输文件时直接在磁盘和tcp socket之间传输数据。如果这个参数不开启,会先在用户空间(Nginx进程空间)申请一个buffer,用read函数把数据从磁盘读到cache,再从cache读取到用户空间的buffer,再用write函数把数据从用户空间的buffer写入到内核的buffer,最后到tcp socket。开启这个参数后可以让数据不用经过用户buffer。
文件读取配置
sendfile
syntax: sendfile on | off;
default:sendfile off
context:http,server,location,if in location
2. tcp_nopush
- 在 sendfile 开启的情况下,提高网络数据包的传输效率。
tcp_nopush指令,在连接套接字时启用Linux系统下的TCP_CORK。该选项告诉TCP堆栈附加数据包,并在它们已满或当应用程序通过显式删除TCP_CORK指示发送数据包时发送它们。 这使得发送的数据分组是最优量,并且因此提高了网络数据包的传输效率。
也就是说 tcp_nopush=on 时,结果就是数据包不会马上传送出去,等到数据包最大时,一次性的传输出去,这样有助于解决网络堵塞,虽然有一点点延迟。
配置
Syntax: tcp_nopush on | off;
Default: tcp_nopush off;
Context: http, server, location
3. tcp_nodelay
在 keepalive 连接下,提高网络数据包的传输实时性。
tcp_nodelay选项和tcp_nopush正好相反,数据包不等待,实时发送给用户。
配置:
Syntax: tcp_nodelay on | off;
Default: tcp_nodelay off;
Context: server, location
4. 压缩
开启压缩,可以加快资源响应速度,同时节省网络带宽资源。
开启关闭压缩:
Syntax: gzip on | off;
Default: gzip off;
Context: http, server, location, if in location
配置压缩比,压缩等级配置(压缩等级越高,越消耗服务器资源)
Syntax: gzip_comp_level level;
Default: gzip_comp_level 1;
Context: http, server, location
gzip协议版本配置
Syntax: gzip_http_version 1.0 | 1.1;
Default: gzip_http_version 1.1;
Context: http, server, location
压缩扩展模块
预读gzip功能 ngx_http_gzip_static_module
Syntax: gzip_static on | off | always;
Default: gzip_static off;
Context: http, server, location
应用支持gunzip的压缩方式 ngx_http_gunzip_module
Syntax: gunzip on | off;
Default: gunzip off;
Context: http, server, location
Syntax: gunzip_buffers number size;
Default: gunzip_buffers 32 4k|16 8k;
Context: http, server, location
5.缓存
缓存:http协议定义的缓存机制(如:expires,cache-control 等)
无缓存情况:
配置:
syntax: expires [modified] time;
expires epoch | max | off;
default: expires off;
context:http, server, location