这是你所了解的Nginx吗?

Nginx概念

Nginx 是一款面向性能设计的 HTTP 服务器,相较于 Apache、lighttpd 具有占有内存少,稳定性高等优势,同时也是一个非常高效的反向代理、负载平衡服务器

nginx使用的是反应器模式,主事件循环等待操作系统发出准备事件的信号,这样数据就可以从套接字读取,在该实例中读取到缓冲区并进行处理,单个线程可以提供数万个并发连接

nginx在启动后会有一个master进程和多个worker进程,是以多进程的方式来进行工作的,master进程来读取及评估配置和维持,worker进程来处理请求

worker_processes  4;

可以看到现在就有四个worker进程了

 ps -ef | grep nginx
  501  4106     1   0 10:43上午 ??         0:00.01 nginx: master process nginx
  501 11007  4106   0  5:00下午 ??         0:00.00 nginx: worker process
  501 11008  4106   0  5:00下午 ??         0:00.00 nginx: worker process
  501 11009  4106   0  5:00下午 ??         0:00.00 nginx: worker process
  501 11010  4106   0  5:00下午 ??         0:00.00 nginx: worker process

master进程主要用来管理worker进程,多个worker进程来竞争客户端的请求

每个worker进程能够使用异步非阻塞的方式处理多个客户端请求,当某个worker进程接收到客户端的请求后,会调用IO进行处理,如果不能立即得到结果,worker进程就会去处理其他请求。当IO返回结果后,会通知worker进程,而worker进程得到通知后,就会挂起当前正在处理的事务,拿IO返回结果去响应客户端请求。worker进程采用的是epoll事件驱动模型和IO进行通信的,底层使用回调callback替代轮询,效率会高于select模型

反向代理

对于正向代理来说,需要在浏览器配置代理服务器,通过代理服务器去访问目标服务器,而反向代理是不需要在浏览器进行配置的,浏览器对此是无感知的,只需要将请求发送到反向代理服务器,再由反向代理服务器去选择目标服务器获取数据后,再返回给客户端,对外暴露的是反向代理服务器的地址,隐藏了真实服务器的IP地址

负载均衡

在最初项目起步的时候,是由客户端访问单个服务器,但是由于并发以及高可用的一些要求,需要增加服务器的数量,将请求分发到不同的服务器上,此时将原本一个服务器的压力分散到多个服务器上,就是负载均衡

动静分离

为了加快网站的解析速度,把动态页面和静态页面由不同的服务器解析,来加快解析速度

https://zhhll.icu/2021/服务器/Nginx/3.Nginx概念/


原文始发于微信公众号(bug生产基地):这是你所了解的Nginx吗?

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/176459.html

(0)
java小白的头像java小白

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!