1.设置worker进程的用户,linux中的用户,涉及到nginx操作目录或文件的一些权限,默认为nobody
user root;
2.worker进程数,设置数与cpu相同或比cpu少一个
worker_processes 1;
3.nginx日志级别 | debug | info| notice | warn | error | crit | alert | emerg |,错误级别从左到右越来越大
error_log logs/error.log notice; error_log logs/error.log info;
4.设置nginx进程pid
pid logs/nginx.pid
5.设置工作模式
events{ #默认使用epoll use epoll; #每个worker允许连接的客户端最大数 worker_connections 1024; }
6.include引入外部配置,提高可读性,可以避免配置文件过大
include mime.types;
7.设置日志输出格式,main为定义的格式名称,access_log可以直接使用这个变量
log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer"' '"$http_user_agent" "$http_x_forwarded_for"'; access_log log/access.log main;
参数解析
参数名 | 参数意义 |
---|---|
$remote_addr | 客户端ip |
$remote_user | 远程客户端用户名,一般为‘-’ |
$time_local | 时间和时区 |
$request | 请求的url以及method |
$status | 响应状态码 |
$body_bytes_sent | 响应客户端内容字节数 |
$http_referer | 记录用户从哪个连接跳过来的 |
$http_user_agent | 用户所使用的代理 |
$http_x_forwarded_for | 通过代理服务器来记录客户端ip |
8.sendfile使用高效文件传输,提高传输性能。启用后才能使用tcp_nopush,tcp_nopush是指当数据表积累一定大小后才发送,提高了效率
sendfile on; tcp_nopush on;
9.keepalive_timeout 设置客户端与服务器端请求的超时时间,保证客户端多次请求的时候不会重复建立新的连接,节约资源损耗。
keepalive_timeout 65; # keepalive_timeout 0;
10. gzip启用压缩,html/js/css压缩后传输会更快
gzip on;
11.server可以在http指令块中设置多个虚拟主机
werver{ location / { root myhtml; index myindex.html index.htm; } }