首页 > 技术文章 > nginx

wolfstark 2022-02-07 11:34 原文

https://www.cnblogs.com/mpyidudu/p/15689594.html

 

默认配置

#全局块,主要设置Nginx服务器整体运行的配置指令 worker_processes 1; #events块,主要设置,Nginx服务器与用户的网络连接,这一部分对 Nginx服务器的性能影响较大 events { worker_connections 1024; } #http块,是Nginx服务器配置中的重要部分,代理、缓存、日志记录、 第三方模块配置... http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; #server块,是Nginx配置和虚拟主机相关的内容 server { listen 80; server_name localhost; #location块,基于Nginx服务器接收请求字符串与 location后面的值进行匹配,对特定请求进行处理 location / { root html; index index.html index.htm; } } }

nginx.conf配置文件中默认有三大块:全局块、events块、http块
http块中可以配置多个server块,每个server块又可以配置多个location块

全局块

user指令

user: 用于配置运行Nginx服务器的worker进程的用户和用户组

该属性也可以在编译的时候指定,语法如下./configure --user=user --group=group ,如果两个地方都进行了设置,最终生效的是配置文件中的配置。
image

# 验证配置文件合法性 ../sbin/nginx -t

添加 www 用户后 重启nginx 发现worker进程已经属于 www 用户

useradd www ../sbin/nginx -s reload ps -ef |grep nginx

image

使用user指令可以指定启动运行工作进程的用户及用户组,这样对于系统的权限访问控制的更加精细,也更加安全。

work process指令

master_process: 用来指定是否开启工作进程。
worker_processes: 用于配置Nginx生成工作进程的数量,这个是Nginx服务器实现并发处理服务的关键所在。理论上来说workder process的值越大,可以支持的并发处理量也越多,但事实上这个值的设定是需要受到来自服务器自身的限制,建议将该值和服务器CPU的内核数保存一致。

master_process on|off; worker_processes num/auto;

其他指令

  1. daemon on|off;:设定Nginx是否以守护进程的方式启动。
    守护式进程是linux后台执行的一种服务进程,特点是独立于控制终端,不会随着终端关闭而停止。
语法daemon on/off;
默认值 daemon on;
位置 全局块
  1. pid file;: 用来配置Nginx当前master进程的进程号ID存储的文件路径。
语法pid file;
默认值 默认为:/usr/local/nginx/logs/nginx.pid
位置 全局块
  1. error_log: 用来配置Nginx的错误日志存放路径
    该属性可以通过./configure --error-log-path=PATH来指定

    其中日志级别的值有:debug|info|notice|warn|error|crit|alert|emerg,翻译过来为 调试|信 息|通知|警告|错误|临界|警报|紧急,这块建议大家设置的时候不要设置成info以下的等级,因为会带来大量的磁盘I/O消耗,影响Nginx的性能。

语法error_log file [日志级别];
默认值 error_log logs/error.log error;
位置 全局块、http、server、location
  1. include: 用来引入其他配置文件,使Nginx的配置更加灵活
语法include file;
默认值
位置 any

events块

  1. accept_mutex: 用来设置Nginx网络连接序列化
语法accept_mutex on/off;
默认值 accept_mutex on;
位置 events

这个配置主要可以用来解决常说的"惊群"问题。大致意思是在某一个时刻,客户端发来一个请求连接,Nginx后台是以多进程的工作模式,也就是说有多个worker进程会被同时唤醒,但是最终只会有一个进程可以获取到连接,如果每次唤醒的进程数目太多,就会影响Nginx的整体性能。如果将上述值设置为on(开启状态),将会对多个Nginx进程接收连接进行序列号,一个个来唤醒接收,就防止了多个进程对连接的争抢。

  1. multi_accept: 用来设置是否允许同时接收多个网络连接
语法multi_accept on/off;
默认值 multi_accept off;
位置 events

如果multi_accept被禁止了,nginx一个工作进程只能同时接受一个新的连接。否则,一个工作进程可以同时接受所有的新连接

  1. worker_connections:用来配置单个worker进程最大的连接数
worker_commections 512;

这里的连接数不仅仅包括和前端用户建立的连接数,而是包括所有可能的连接数。另外,number值不能大于操作系统支持打开的最大文件句柄数量。

  1. use: 用来设置Nginx服务器选择哪种事件驱动来处理网络消息。

注意:此处所选择事件处理模型是Nginx优化部分的一个重要内容,method的可选值有select/poll/epoll/kqueue等,之前在准备centos环境的时候,我们强调过要使用linux内核在2.6以上,就是为了能使用epoll函数来优化Nginx。

events指令配置实例

events{ accept_mutex on; multi_accept on; worker_commections 1024; use epoll; }

http块

定义MIME-Type

我们都知道浏览器中可以显示的内容有HTML、XML、GIF等种类繁多的文件、媒体等资源,浏览器为了区分这些资源,就需要使用MIME Type。所以说MIME Type是网络资源的媒体类型。Nginx作为web服务器,也需要能够识别前端请求的资源类型。

在Nginx的配置文件中,默认有两行配置

include mime.types; default_type application/octet-stream;

default_type: 用来配置Nginx响应前端请求默认的MIME类型。

语法default_type mime-type;
默认值 default_type text/plain;
位置 http、server、location

在default_type之前还有一句include mime.types ,include之前我们已经介绍过,相当于把mime.types文件中MIMT类型与相关类型文件的文件后缀名的对应关系加入到当前的配置文件中。

有些时候请求某些接口的时候需要返回指定的文本字符串或者json字符串,如果逻辑非常简单或者干脆是固定的字符串,那么可以使用nginx快速实现,这样就不用编写程序响应请求了,可以减少服务器资源占用并且响应性能非常快。

location /get_text { #这里也可以设置成text/plain default_type text/html; return 200 "This is nginx's text"; } location /get_json{ default_type application/json; return 200 '{"name":"TOM","age":18}'; }

自定义服务日志

Nginx中日志的类型分access.logerror.log

  • access.log: 用来记录用户所有的访问请求。
  • error.log: 记录nginx本身运行时的错误信息,不会记录用户的访问请求。

Nginx服务器支持对服务日志的格式、大小、输出等进行设置,需要使用到两个指令,分别是access_loglog_format

  1. access_log: 用来设置用户访问日志的相关属性。
语法access_log path[format[buffer=size]]
默认值 access_log logs/access.log combined;
位置 http , server , location
  1. log_format: 用来指定日志的输出格式。
语法log_format name [escape=default/json/none] string....;
默认值 log_format combined "...";
位置 http

其他配置指令

  1. sendfile: 用来设置Nginx服务器是否使用sendfile()传输文件,该属性可以大大提高Nginx处理静态资源的性能
语法sendfile on/off;
默认值 sendfile off;
位置 http、server、location
  1. keepalive_timeout: 用来设置长连接的超时时间。
语法keepalive_timeout time;
默认值 keepalive_timeout 75s;
位置 http、server、location
  1. keepalive_requests: 用来设置一个keep-alive连接使用的次数。
语法keepalive_requests number;
默认值 keepalive_requests 100;
位置 http、server、location

 

__EOF__

推荐阅读