• 【Nginx】基础概念和核心配置块


    1.Nginx基础概念

    Nginx一个具有高性能的【HTTP】和方向代理WEB服务器,同时也是一个POP3/SMTP/IMAP代理服务器 ,由伊戈尔·赛索耶夫(俄罗斯人)使用C语言编写的。

    特点:占用内存少,并发能力强。

    正向代理

    在了解方向代理以前,需要先明确什么是正向代理。

    正向代理:如果把局域网外的Internet资源想象成一个巨大的资源库,则局域网中的客户端想要访问Internet,则需要通过代理服务器访问。这种访问方式叫做正向代理。

    image-20221110091439480

    方向代理

    ​ 客户端对代理是无感知的(不需要进行配置),只需要将请求发送到方向代理服务器,由反向代理服务器去选择目标服务器,获取数据后,在返回给客户端。此时反向代理服务器和目标服务器对外就是一个服务器。对外暴露的是代理服务器的地址,隐藏了真实的服务器地址。

    image-20221110091911830

    负载均衡

    当请求十分频繁时,单一服务器无法解决问题(如各大电商平台的双11活动),由于摩尔定律失效,我们只能考虑增加服务器的数量,然后将请求分发到各个服务器上。将原先请求集中到单个服务器的情况,改为将请求均匀分发到各个服务器上。

    动静分离

    为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析的速度,降低原来服务器的压力。

    image-20221110161304663

    2.命令和信号控制

    nginx可执行程序默认路径为:

    /usr/local/nginx/sbin
    
    • 1

    目录结构

    image-20221109092328000

    2.1信号控制

    启动nginx

    ./nginx
    
    • 1

    image-20221110165058176

    • Nginx后台进程中包含一个master进程和多个worker进程,master进程主要用来管理worker进程。包含接收外界的信息,并将接收到的信号发送给各个worker进程,监控worker进程的状态,当worker进程出现异常退出后,会自动重新启动新的worker进程。
    • 而worker进程则是专门用来处理用户请求的,各个worker进程之间是平等的并且相互独立,处理请求的机会也是一样的。

    image-20221110165216645

    作为管理员,只需要通过给master进程发送信号就可以来控制Nginx。

    这个时候我们需要有两个前提条件,一个是要操作的master进程,一个是信号。

    获取master进程pid的方式

    • 方法一:ps ajx | grep nginx
    • 方法二:./configure的配置参数的时候,有一个参数是–pid-path=PATH。默认值是/usr/local/nginx/logs/nginx.pid,可以通过查看该文件来获取nginx的master进程ID.

    image-20221110165837828

    信号

    信号作用
    TERM/INT立即关闭整个服
    QUIT"优雅"地关闭整个
    HUP重读配置文件并
    USR1重新打开日志文
    USR2平滑升级到最新
    WINCH所有子进程不在接收处理新连接,相当于给work进程发送QUIT指令
    kill -signal PID
    
    • 1

    QUIT信号和TERM信号的区别

    发送QUIT信号给master进程,master进程会控制所有的work进程不再接收新的请求,等所有请求处理完后,在把进程都关闭掉。而TERM信号是强制立马终止所有的进程。

    2.2命令控制

    此方式是通过Nginx安装目录下的sbin下的可执行文件nginx来进行Nginx状态的控制。

    image-20221110170449765

    • -?和-h:显示帮助信息
    • -v:打印版本号信息并退出
    • -V:打印版本号信息和配置信息并退出
    • -t:测试nginx的配置文件语法是否正确并退出
    • -T:测试nginx的配置文件语法是否正确并列出用到的配置文件信息然后
      退出
    • -q:在配置测试期间禁止显示非错误消息
    • -s:signal信号,后面可以跟 :
    参数作用
    stop[快速关闭,类似于TERM/INT信号的作用]
    quit[优雅的关闭,类似于QUIT信号的作用]
    reopen[重新打开日志文件类似于USR1信号的作用]
    reload[类似于HUP信号的作用]
    -p指定Nginx的prefix路径,(默认为: /usr/local/nginx/)
    -c指定Nginx的配置文件路径,(默认为: conf/nginx.conf)
    -g用来补充Nginx配置文件,向Nginx服务指定启动时应用全局的配置

    3.Nginx核心配置文件结构

    Nginx的核心配置文件默认是放在/usr/local/nginx/conf/nginx.conf 。

    去掉其中的注释后,Nginx的代码如下:

    worker_processes 1;
    
    events {
    	worker_connections 1024;
    } 
    
    http {
    	include mime.types;
    	default_type application/octet-stream;
    	sendfile on;
    	keepalive_timeout 65;
    
        server {
    		listen 80;
    		server_name localhost;
    		location / {
    		root html;
    		index index.html index.htm;
    	} 
            error_page 500 502 503 504 /50x.html;
    		location = /50x.html {
    			root html;
    		}
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

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

    3.1全局块

    从配置文开始到events块之间的内容,主要设置一些影响nginx服务器整体允许的配置指令。

    user指令

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

    语法user user [group]
    默认值nobody
    位置全局块

    image-20221110172357958

    可以看到,默认条件下,worker进程属于nobody。

    该指令的使用步骤:

    1.首先设置一个用户信息

    image-20221110175102705

    2.创建一个用户

    因为在我的Linux环境下,已经配置了一个west用户,所以不需要再添加west用户。如果没有要添加的用户,使用下面的指令配置。

    useradd west
    
    • 1

    使用./nginx -t重新加载配置文件

    image-20221110175641514

    ./nginx -s reload
    ps -ef | grep nginx
    
    • 1
    • 2

    用上面的指令查看现在nginx允许的进程。发现worker用户被修改为了west。

    image-20221110175946435

    3.1.1权限问题

    在/root/html/index.html页面添加html源码,网页的效果为:

    image-20221110184533006

    修改配置文件

    image-20221110234429086

    • 这里的root,表示浏览器搜索资源的起始目录
    • index:请求资源的首页信息
    ./nginx -t 
    ./nginx -s reload
    
    • 1
    • 2

    通过上面的命令重新加载配置

    image-20221110235337166

    在访问时,就会发现报错403;403错误的原因是权限问题。这里worker进程的用户是west,而/root/html/index.html的所有者是root用户,所以无法访问。

    将资源移动到west路径下

    cp -f /root/html /home/west/
    
    • 1

    image-20221111004432928

    修改配置文件,将根目录修改为/home/west/html,再重新加载配置文件。刷新浏览器请求后,得到了想要的页面。

    image-20221111000658859

    3.1.2work process指令

    master_process:用来指定是否开启工作进程

    语法master_process on|off;
    默认值master_process on;
    位置全局块

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

    语法worker_processes num/auto;
    默认值1
    位置全局块

    修改指令worker_processes 2

    image-20221111001159444

    3.1.3其他指令

    daemon:设定Nginx是否以守护进程的方式启动。

    语法daemon on|off;
    默认值daemon on;
    位置全局块

    pid:用来配置Nginx当前master进程的进程号ID存储的文件路径

    语法pid file;
    默认值默认为:/usr/local/nginx/logs/nginx.pid
    位置全局块

    error_log:用来配置Nginx的错误日志存放路径

    语法error_log file [日志级别];
    默认值error_log logs/error.log error;
    位置全局块、http、server、location

    include:用来引入其他配置文件,使Nginx的配置更加灵活

    语法include file;
    默认值
    位置any
    3.2event块

    影响Nginx服务器与用户网络的连接。常用的设置包括:是否开启对多work_process下的网络连接进行反序列化,是否允许同时接收多个网络连接。选取那种事件驱动模型来处理连接请求。每个work_process可以同时支持的最大连接数。

    accept_mutex:用来设置Nginx网络连接序列化

    语法accept_mutex on|off;
    默认值accept_mutex on;
    位置events

    作用:该配置主要用来解决惊群问题

    惊群问题:

    在某一个时刻,客户端发送一个请求。而Nginx后台是以多进程的工作模式,也就是说有多个worker进程会被同时唤醒,但是最终只会有一个进程可以获取连接。

    如果每次唤醒的进程数目太多,就会影响Nginx整体性能。而序列化,将会对多个Nginx进程接收连接进行序列号,一个一个唤醒连接,可以防止多个进程对连接的争抢。

    image-20221111002848827

    multi_accept:用来设置是否允许同时接收多个网络连接

    语法multi_accept on|off;
    默认值multi_accept off;
    位置events

    如果multi_accept被禁止了,nginx一个工作进程只能同时接受一个新的连接。否则,一个工作进程可以同时接受所有的新连接。这也是提高Nginx性能的重要配置。

    worker_connections:用来配置单个worker进程最大的连接数

    语法worker_connections number;
    默认值worker_commections 512;
    位置events

    image-20221111003214722

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

    语法use method;
    默认值根据操作系统定
    位置events

    此处所选择事件处理模型是Nginx优化部分的一个重要内容, 主要的模型有selcet、poll、epoll、kqueue等。我的云服务器的默认值是epoll

    3.3http块

    配置最频繁的部分;代理、缓存和日志定义等绝大多数功能和第三方模块的配置都在这里。

    3.3.1定义MIME_Type

    览器中可以显示的内容有HTML、XML、GIF等种类繁多的文件、媒体等资源,浏览器为了区分这些资源,就需要使用MIMEType。

    所以说MIME Type是网络资源的媒体类型。Nginx作为web服务器,也需要能够识别前端请求的资源类型。

    image-20221111003723723

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

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

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

    配置json文件格式和text文本类型

    image-20221111004852326

    接下来依次访问对应的网址。

    访问/get_json网址

    image-20221111005036766

    访问/get_text网址

    image-20221111005115229

    3.3.2自定义服务日志
    • Nginx中日志的类型分access.log、error.log。
    • access.log:用来记录用户所有的访问请求。
    • error.log:记录nginx本身运行时的错误信息,不会记录用户的访问请求。
    • Nginx服务器支持对服务日志的格式、大小、输出等进行设置,需要使用到两个指令,分别是access_log和log_format指令

    access_log:用来设置用户访问日志的相关属性

    语法access_log path[format[buffer=size]]
    默认值access_log logs/access.log combined;
    位置http , server , location

    log_format:用来指定日志的输出格式。

    语法log_format name [escape=default|json|none] string…;
    默认 值log_format combined “…”;
    位置http

    这里的combined格式就是access_log指令中的combined格式

    自定义服务日志实例

    image-20221111011528998

    image-20221111011303526

    获取日志信息,查看是否配置成功

    cat /root/html/myload.log
    
    • 1

    成功获取了日志

    image-20221111011635798

    3.3.3其他配置指令

    sendfile:用来设置Nginx服务器是否使用sendfile()传输文件,该属性可以大大提高Nginx处理静态资源的性能

    语法sendfile on|off;
    默认值sendfile off;
    位置http、server、location

    keepalive_timeout:用来设置长连接的超时时间。

    语法keepalive_timeout time;
    默认值keepalive_timeout 75s;
    位置http、server、location

    为什么要使用keepalive?

    • 我们都知道HTTP是一种无状态协议,客户端向服务端发送一个TCP请求,服务端响应完毕后断开连接。
    • 如果客户端向服务端发送多个请求,每个请求都需要重新创建一次连接,效率相对来说会下降比较多,使用keepalive模式,可以告诉服务器端在处理完一个请求后保持这个TCP连接的打开状态,若接收到来自这个客户端的其他请求,服务端就会利用这个未被关闭的连接,而不需要重新创建一个新连接,提升效率,但是这个连接也不能一直保持,这样的话,连接如果过多,也会是服务端的性能下降,这个时候就需要我们进行设置其的超时时
      间。

    **keepalive_requests:用来设置一个keep-alive连接使用的次数。 **

    语法keepalive_requests number;
    默认值keepalive_requests 100;
    位置http、server、location
    3.4serve和location块

    serve和location块是Nginx配置的关键配置块。详细的内容将在后面讲解

    server {
    	listen 80;
    	server_name localhost;
    	location / {
    		root html;
    		index index.html index.htm;
    	}
        error_page 500 502 503 504 404 /50x.html;
    	location = /50x.html {
    		root html;
    	}
    }	
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • root: 根目录
    • index:资源请求的首页
    • error_page:匹配的错误码
  • 相关阅读:
    如何准备一场Java面试?
    【LeetCode】779. 第K个语法符号
    【云原生 | Kubernetes 系列】--Gitops持续交付 Tekton Pipeline使用进阶(pvc和Results)
    羧酸-COOH功能化修饰红色荧光聚苯乙烯AIE微球的产品组成和保存条件
    C++的deque(双端队列),priority_queue(优先级队列)
    解决方案| anyRTC远程检修应用场景
    打开MySQL数据库
    安装和初步使用 nn-Meter
    贵阳RapidSSL的ssl证书适合个人网站吗
    探讨C#、C++和Java这三门语言在嵌入式的地位
  • 原文地址:https://blog.csdn.net/qq_53893431/article/details/127799005