Nginx详细介绍(并从技术层面深度剖析)

nginx介绍

  • 1.nginx 介绍
  • 2.nginx的优势
  • 3.Nginx VS Apache
    • 3.1.内核、语言、诞生时间比较
    • 3.2.功能比较
    • 3.3.Nginx 相对 apache 的优点
  • 4.Nginx为什么有这么多的优势?
    • 4.1.IO多路复用(I/O multiplexing【多并发】)
    • 4.2.nginx的驱动模型介绍
    • 4.3.nginx的异步非阻塞模式
    • 4.4.理解同步、异步、阻塞、非阻塞

1.nginx 介绍

Nginx (engine x) 是一个轻量级,高性能的 HTTP 和 反向代理 服务,也是一个IMAP/POP3/SMTP服务。因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好。

2.nginx的优势

  • Nginx 是一个高性能的 Web 和反向代理服务器,它具有有很多非常优越的特性
  • 作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率,这点使 Nginx 尤其受到虚拟主机提供商的欢迎。能够支持高达 50,000 个并发连接数的响应。
  • 作为负载均衡服务器:可以进行自定义配置,支持虚拟主机,支持URL重定向,支持网络监控,支持流媒体传输等。Nginx 既可以在内部直接支持 Rails 和 PHP,也可以支持作为 HTTP代理服务器对外进行服务。Nginx 用 C 编写,不论是系统资源开销还是 CPU 使用效率都比 Perlbal 要好的多。
  • 作为邮件代理服务器: Nginx 同时也是一个非常优秀的邮件代理服务器(最早开发这个产品的目的之一也是作为邮件代理服务器)。
  • Nginx 安装非常的简单,配置文件 非常简洁(还能够支持perl语法),Bugs非常少的服务器
  • Nginx 启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。nginx还能够在不间断服务的情况下进行软件版本的升级。

nginx的优点:
1、高并发,高性能(单机环境下参考服务器配置,并发连接数在7000+到8000左右。集群模式20000+)
2、高可靠。可以7*24小时不间断运行
3、可扩展性强。模块化设计,使得添加模块非常的平稳。
4、支持热部署。可以在不停止服务器的情况下升级nginx
5、BSD许可证。nginx不止开源免费的,我们还可以更具实际需求进行定制修改源代码

3.Nginx VS Apache

3.1.内核、语言、诞生时间比较

最大的区别:事件驱动模型不一样,nginx使用的是异步非阻塞模式,apache使用的同步阻塞模式。

特性NginxApache
请求管理事件驱动模型,使用异步套接字处理,占用较少的内存和CPU开销同步套接字、进程和线程每个请求都要使用一个单独的进程或线程,使用同步套接字
设计语言CC、C++
可移植性多平台多平台
诞生时间20021994

3.2.功能比较

功能NginxApache
HTTPS支持作为模块支持作为模块支持
虚拟主机原生支持原生支持
CGI支持仅支持FastCGI支持CGI和FastCGI
系统模块静态模块系统动态模块系统

FastCGI的介绍
快速通用网关接口(Fast Common Gateway Interface/FastCGI)是通用网关接口(CGI)的改进,描述了客户端和服务器程序之间传输数据的一种标准。
FastCGI致力于减少Web服务器与CGI程序之间互动的开销,从而使服务器可以同时处理更多的Web请求。
与为每个请求创建一个新的进程不同,FastCGI使用持续的进程来处理一连串的请求。这些进程由FastCGI进程管理器管理,而不是web服务器。
从以上功能上的对比,我们很难发现哪些功能Apache无法实现。

3.3.Nginx 相对 apache 的优点

  • 轻量级,同样是web服务器比Apache 占用更少的内存及资源
  • apache采用的就是进程和线程模式工作,来一个请求就开启一个进程或者线程,大大的占用系统的资源
  • 开源免费(费用)
  • 静态处理性能强:Nginx 静态处理性能比 Apache 高 3倍以上(性能)
  • 抗高并发:Nginx是采用异步非阻塞来处理请求的,而Apache则是阻塞型的。在高并发下Nginx 能保持低资源低消耗高性能。
  • 在Apache+PHP(prefork)模式下,如果PHP处理慢或者前端压力很大的情况下,很容易出Apache进程数飙升,从而出现拒绝服务的现象。
  • 高度模块化的设计:编写模块相对简单(功能多);
  • 解决了强耦合的问题,让代码依赖性变低变弱,甚至是互不干扰的工作,让我们定制软件提供了很大的便利,就是可以自定义安装模快;如果只使用3个模快,你给我装20个模快,那就浪费了我系统的资源。
  • 社区活跃:各种高性能模块出品迅速(可维护性成本低)

4.Nginx为什么有这么多的优势?

从技术层面深度剖析nginx程序的设计思想

4.1.IO多路复用(I/O multiplexing【多并发】)

多并发在生活中的案例:超市收银口的收银员,将每个收银口看成一个处理请求的线程,当人数不多的时候,开一个收银口一个收银员就能应付,但是当人数多起来了,一个收银口应付不来那么多人了(对应的是海量的请求),这时就需要开启多个收银口来应对大量的顾客,而顾客则可以根据收银员的忙碌程度进程自由选择的排队

  • 第一种方法就是最传统的多进程并发模型 (每进来一个新的I/O流会分配一个新的线程管理。)
    1
  • 第二种方法就是I/O多路复用 (单个线程,通过记录跟踪每个I/O流(sock)的状态,来同时管理多个I/O流 );发明它的原因,是尽量多的提高服务器的吞吐能力。在同一个线程里面, 通过拨开关的方式,来同时传输多个I/O流
    2

4.2.nginx的驱动模型介绍

一个请求到来了,nginx使用epoll接收请求的过程是怎样的?

  • select,poll,epoll 都是I/O多路复用的具体的实现,其实是他们出现是有先后顺序的。
  • I/O多路复用这个概念被提出来以后, 相继出现了多个方案,但是都需要linux内核支持
  • select是第一个实现 (1983 左右实现的)。 select 被实现以后,很快就暴露出了很多问题。
    • select 任何一个sock(I/O stream)出现了数据,select 仅仅会返回,但是并不会告诉你是那个sock上有数据,于是你只能自己一个一个的找,10几个sock可能还好,要是几万的#sock每次都找一遍就跟快递员送快递一样,每次快递到了都得你自己去快递箱里面找,可想而知多麻烦
    • select 只能监视1024个链接。
    • select 线程不是安全的。
  • 于是14年以后(1997年)一帮人又实现了poll, poll 修复了select的很多问题,比如
    • poll 去掉了1024个链接的限制,于是可以有多个连接进来。​但是poll仍然线程不是安全的,这就意味着,不管服务器有多强悍,也只能在一个线程里面处理一组I/O流。
  • epoll:可以说是I/O 多路复用最新的一个实现,epoll 修复了poll 和select绝大部分问题,比如
    • epoll 现在是线程安全的。
    • epoll 现在不仅告诉你sock组里面数据,还会告诉你具体哪个sock有数据,你不用自己去找了。

ngnix会有很多连接进来, 默认采用epoll会把他们都监视起来,然后像拨开关一样,谁有数据就拨向谁,然后调用相应的代码处理。

4.3.nginx的异步非阻塞模式

//查看服务器中nginx的worker进程
# yum -y install  psmisc
# pstree |grep nginx|-+= 81666 root nginx: master process nginx| |--- 82500 nobody nginx: worker process| \--- 82501 nobody nginx: worker process
//1个master进程和n个work进程

每进来一个request,会有一个worker进程去处理。但不是全程的处理,处理到什么程度呢?
处理到可能发生阻塞的地方,比如向上游(后端)服务器转发request,并等待请求返回。
那么,这个处理的worker不会这么一直等着,他会在发送完请求后,注册一个事件:“如果upstream返回了,告诉我一声,我再接着干”。于是他就休息去了。这就是【异步】。
此时,如果再有request 进来,他就可以很快再按这种方式处理。这就是非阻塞和IO多路复用。而一旦上游服务器返回了,就会触发这个事件,worker才会来接手,这个request才会接着往下走。这就是【异步回调】。

4.4.理解同步、异步、阻塞、非阻塞

当我们使用一个简单的读取文件的操作来举例说明:

  1. 同步阻塞(Synchronous Blocking):
    在同步阻塞模式下,程序发起读取文件的请求后,会一直等待文件读取完成,期间无法进行其他操作。只有当文件读取完成后,程序才能继续执行后续操作。
  2. 异步阻塞(Asynchronous Blocking):
    在异步阻塞模式下,程序发起读取文件的请求后,会立即返回并继续执行其他操作。但是程序会周期性地查询文件是否已经读取完成,如果未完成,则会一直等待,直到文件读取完成后再继续执行后续操作。
  3. 同步非阻塞(Synchronous Non-blocking):
    在同步非阻塞模式下,程序发起读取文件的请求后,会立即返回并继续执行其他操作。程序会不断地轮询文件是否已经读取完成,如果未完成,则会立即返回并继续轮询,直到文件读取完成后再继续执行后续操作。
  4. 异步非阻塞(Asynchronous Non-blocking):
    在异步非阻塞模式下,程序发起读取文件的请求后,会立即返回并继续执行其他操作。当文件读取完成后,系统会通过回调函数或者事件通知的方式来通知程序文件已经读取完成,程序再进行后续处理。

同步和异步是针对程序等待操作完成的方式,阻塞和非阻塞是针对程序等待I/O操作完成的方式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/635014.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

初始js,js的变量

js起源 由布兰登,艾奇在1995年进行开发 JavaScript和ECMAScript的关系 ECMAScript (简称“ES”) 核心( ECMAScript ):提供语⾔的语法和基本对象 ⽂档对象模型( DOM )&#xff1…

削峰填谷与应用间解耦:分布式消息中间件在分布式环境下并发流量控制的应用

这是《百图解码支付系统设计与实现》专栏系列文章中的第(18)篇,也是流量控制系列的第(4)篇。点击上方关注,深入了解支付系统的方方面面。 本篇重点讲清楚分布式消息中间件的特点,常见消息中间件…

MiniTab的相关性统计

相关概述 相关可以度量两个变量之间关联的强度和方向。可以在以下两种相关方法之间进行选择:Pearson 积矩相关和 Spearman 秩次相关。Pearson 相关(又称为 r)是最常见的方法,它度量两个连续变量之间的线性关系。 如果变量之间的…

通讯录项目的实现以及动态顺序表(基于顺序表)

首先我们要知道什么是顺序表: 顺序表的底层结构是数组,对数组的封装,实现了常⽤的增删改查等接⼝,顺序表分为静态顺序表(使⽤定⻓数组存储元素)和动态顺序表(按需申请) 静态顺序表缺点: 空间给少了不够⽤,给多了造成空间浪费 拿出来我之前以及写好了的顺序表的代码:…

SQL SERVER无法连接到服务器解决过程记录

很久没用sql server了,这几天打算更新SQL SERVER数据库:SQL看这一篇就看够了(附详细代码及截图) 这篇文章,发现连接不上服务器。 找一下解决办法。 一、打开服务界面 在键盘上按“WINR”快捷键,打开运行…

rust使用protobuf

前言 c,java,go 等直接是用 ,具体就不说了,这章主要讲述rust 使用protobuf 这章主要讲述2种 1 > protoc protoc-gen-rust plugin 2> protoc prost-build 1:环境 win10 rustrover64 25-2 下载地址 https://github.com/protocolbu…

【DFS】695.岛屿的最大面积

题目 法1:DFS 最简单的DFS必须掌握!!! class Solution {public int maxAreaOfIsland(int[][] grid) {int m grid.length, n grid[0].length, ans 0;if (m 0 || n 0) {return ans;}boolean[][] visited new boolean[m][n]…

简单实用的恒温控制器

工作原理如下:ST是WTQ-288型电接点压力式温度计,当恒温箱内的温度降低到下限时,ST的指针与下限接点接触,双向可控硅通过R被强制触发导通,接通加热器RL的电源,于是恒温箱内温度上升。ST的指针转动&#xff0…

插入排序(一)——直接插入排序与希尔排序

目录 一.前言 二.排序的概念及其运用 1.1排序的概念 1.2 常用排序算法 三.常用排序算法的实现 3.1 插入排序 3.1.1 基本思想 3.1.2 直接插入排序 3.1.3 希尔排序(缩小增量排序) 四.全部代码 sort.c sort.h test.c 五.结语 一.前言 本文我们…

REPLACE INTO

简介 在数据库中,REPLACE INTO 是一种用于插入或更新数据的(DML) SQL 语句。它与 INSERT INTO 语句类似,但具有一些特殊的行为。 语法 REPLACE INTO table_name (column1, column2, ...) VALUES (value1, value2, ...); repla…

360 C++ 面试真题

1、虚函数表的机制 虚函数的声明和定义:在基类中声明一个函数为虚函数,然后在派生类中进行重写(override)。 class Base { public:virtual void virtualFunction() {// 虚函数的定义} }; ​ class Derived : public Base { publi…

使用antd design pro 及后端nodejs express 结合minio进行文件的上传和下载管理

使用Ant Design Pro前端框架结合Node.js Express后端服务以及MinIO作为对象存储,实现文件上传和下载管理的基本步骤如下: 1. 安装所需依赖 在Node.js Express项目中安装minio客户端库: npm install minio --save 在前端项目(假…

c语言字符串分割函数strtok_s和strtok

strtok_s和strtok是C语言提供的字符串分割函数,用于将一个字符串按照指定的分隔符进行分割成多个子字符串。 strtok_s是C11标准库中提供的安全版本的字符串分割函数,其基本语法如下: char* strtok_s(char* str, const char* delim, char** …

航空飞行器运维VR模拟互动教学更直观有趣

传统的二手车鉴定评估培训模式存在实践性不强、教学样本不足、与实际脱节等一些固有的不足。有了VR虚拟仿真技术的加持,二手车鉴定评估VR虚拟仿真实训系统逐渐进入实训领域,为院校及企业二手车检测培训提供了全新的解决方案。 高职院校汽车专业虚拟仿真实…

DC-3靶机刷题记录

靶机下载地址: 链接:https://pan.baidu.com/s/1-P5ezyt5hUbmmGMP4EI7kw?pwdrt2c 提取码:rt2c 参考: http://t.csdnimg.cn/hhPi8https://www.vulnhub.com/entry/dc-32,312/ 官网http://t.csdnimg.cn/5mVZ7DC-3 (1).pdfhttps://…

模具制造企业ERP系统有哪些?企业怎么选型适配的软件

模具的生产管理过程比较繁琐,涵盖接单报价、车间排期、班组负荷评估、库存盘点、材料采购、供应商选择、工艺流转、品质检验等诸多环节。 有些采用传统管理手段的模具制造企业存在各业务数据传递不畅、信息滞后、不能及时掌握订单和车间生产情况,难以对…

【CF比赛记录】 —— Codeforces Round 920 (Div. 3)(A、B、C、D)

🌏博客主页:PH_modest的博客主页 🚩当前专栏:CF比赛记录 💌其他专栏: 🔴每日一题 🟡 cf闯关练习 🟢 C语言跬步积累 🌈座右铭:广积粮,缓…

学习使用微信小程序实现智能名片电子名片功能代码

学习使用微信小程序实现智能名片电子名片功能代码 拨打手机号功能一键复制信息功能定位导航功能存入手机通讯录功能转发分享功能 拨打手机号功能 wx.makePhoneCall({phoneNumber: qipa250 //仅为示例,并非真实的电话号码 })一键复制信息功能 wx.getClipboardData(…

【ARMv8M Cortex-M33 系列 7.1 -- xPSR | CFSR | HFSR | BFAR | MMFAR 寄存器】

文章目录 问题背景Cortex-M33 Fault 寄存器介绍xPSR (程序状态寄存器)CFSR (可配置故障状态寄存器)HFSR (硬件故障状态寄存器)BFAR (总线故障地址寄存器)MMFAR (内存管理故障地址寄存器) 问题背景 由于在RA4M2(Cortex-M33)移植RT-Thread OS的时候遇到了…

mysql limit

语法 SELECT * FROM TABLE_NAME LIMIT 起始位置,偏移量注: 起始位置从0开始 示例 查询的第1条数据到第100条数据 limit 0,100查询的第101条数据到第200条数据 limit 100,100注意不要用 limit 101,100示例2 limit 语句应放在order by语句后面执行 …