当前位置: 首页 > news >正文

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概念/

本文由 mdnice 多平台发布

http://www.lryc.cn/news/188478.html

相关文章:

  • vim基础指令(自用)
  • 【centos7安装ElasticSearch】
  • ElementPlus Switch 开关基础使用
  • Spring Boot:自定义注解--annotation
  • WIFI频段
  • Java的引用详解与示例
  • c++视觉处理---霍夫变换
  • el-table 边框颜色修改 简单有效!
  • Zabbix第二部分:基于Proxy分布式部署实现Web监控和Zabbix HA集群的搭建
  • JumpServer rce深入剖析
  • EasyExcel导入/导出Excel文件
  • 力扣(LeetCode)2512. 奖励最顶尖的K名学生(C++)
  • CubeMX+BabyOS 使用方法
  • OpenResty安装-(基于Nginx的高性能Web平台,可在Nginx端编码业务)
  • 算法-DFS+记忆化/动态规划-不同路径 II
  • 黑盒测试方法:原理+实战
  • SQLite事务处理
  • Java中CountDownLatch使用场景
  • 漏刻有时数据可视化Echarts组件开发(41)svg格式地图应用
  • firefox的主题文件位置在哪?记录以防遗忘
  • Vuex获取、修改参数值及异步数据处理
  • 【 OpenGauss源码学习 —— 列存储(autoanalyze)(二)】
  • 使用postman 调用 Webservice 接口
  • 程序员Google插件推荐
  • 机器学习中常见的监督学习方法和非监督学习方法有哪些。
  • UEFI基础——测试用例Hello Word
  • 【tomcat、java】
  • 京东获取推荐商品列表 API
  • rust cfg的使用
  • 电脑屏幕怎么录制?5 个最佳免费录屏软件