nginx.conf配置项
环境:centos7 nginx1.16.1
以下配置均在配置文件中进行:/etc/nginx/nginx.conf
1.设置工作进程的所有者和所属组
user 所有者 所属组;
设置后要在操作系统中设置该用户和用户组
/usr/sbin/groupadd www /usr/sbin/useradd -g www www
2. 网络连接事件模型设置
event{
accept_mutex on; #设置网路连接序列化,防止惊群现象发生,默认为on
multi_accept on; #设置一个进程是否同时接受多个网络连接,默认为off
worker_connections 1024; #每个工作进程的最大连接数,默认为512
use epoll; #参考事件模型,use [ kqueue | rtsig | epoll | /dev/poll | select | poll ];
}
3. 服务器返回文件的MIME类型设置
include mime.types; #引入的mime.types文件用来帮助http协议判断网页文件的MIME类型,该项作用域 http server
mime.types文件:文件扩展名与文件类型映射表 服务器根据mime.types文件,由网页文件扩展名得到其MIME类型,并加在响应头中发送给浏览器
default_type application/octet-stream #当文件类型未定义时,默认返回的MIME类型。作用域为 location http
注意:图片,音频,视频等文件要在html文件才能被浏览器展示和播放,但如果不设置default_type application/octet-stream 这一项,服务器直接返回MIME类型为
image/jpeg ,audio/mp4...的响应头,浏览器不会有任何动作,设置此类文件为二进制流后,浏览器接受到该响应头,会产生一个下载窗口,从而在客户端获取服务器文件
设置MIME类型为application/octet-stream(二进制流文件,浏览器打开会出现下载)
4. 客户端相关配置
client_max_body_size 10m; #客户端请求服务器时发送的请求主体最大容量。该配置项作用域http,server,location 。值为0,则不受限制
client_header_buffer_size 32k; #用于指定来自客户端请求头缓冲区大小,对于大多数请求,1KB的缓冲区大小已经足够,如果自定义了消息头或有更大的cookie,可以增加缓冲区大小。
large_client_header_buffers 4 64k; #设置客户端请求头的缓冲区的最大数目和大小。请求行不能超过一个缓冲区的大小,请求头字段也不能超过一个缓冲区的大小。缓冲区仅按需分配。
默认情况下,缓冲区大小等于8K字节。如果在请求处理结束后,连接转换为keep alive状态,则释放这些缓冲区。
client_body_temp_path filename [level1] [level2 ] [lever3 ]; #设定服务器用于存储客户端请求报body部分的临时存储路径及子目录结构和数量
level1:一级目录个数,1表示目录数不超过1位16进制数,故最大值为16
level2:二级目录个数,2表示目录数不超过2位16进制数,故最大值为16*16=256
level3:三级目录个数
client_body_buffer_size 32k; #设定服务器用于接收每个客户端请求报文的body部分的缓冲区大小;默认为16k;
5. 文件传输方式设置
sendfile on; #以sendfile方式传输文件,默认开启。作用域:http location server
指定是否使用sendfile系统调用来传输文件。sendfile系统调用在两个文件描述符之间直接传递数据(完全在内核中操作),
从而避免了数据在内核缓冲区和用户缓冲区之间的拷贝,操作效率很高,被称之为零拷贝。
- 调用read函数,文件数据拷贝到内核缓冲区
- read函数返回,数据从内核缓冲区拷贝到用户缓冲区
- 调用write/send函数,将数据从用户缓冲区拷贝到内核socket缓冲区
- 数据从内核socket缓冲区拷贝到协议引擎中
在这个过程当中,文件数据实际上是经过了四次拷贝操作:
硬盘—>内核缓冲区—>用户缓冲区—>内核socket缓冲区—>协议引擎
sendfile传输方式:
1. sendfile系统调用利用DMA引擎将文件数据拷贝到内核缓冲区,之后数据被拷贝到内核socket缓冲区中
2. DMA引擎将数据从内核socket缓冲区拷贝到协议引擎中
6. 设置超时
(1)客户端请求头超时时间
address 监听的主机,即web服务主机
default_server 该虚拟主机设定为默认虚拟主机
ssl 限制仅能够通过ssl连接提供服务,即只能以https访问
backlog=number 超过并发连接数后,新请求进入后援队列的长度
rcvbuf=size 接收缓冲区大小
sndbuf=size 发送缓冲区大小