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

这篇具有很好参考价值的文章主要介绍了Nginx详细介绍(并从技术层面深度剖析)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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使用的同步阻塞模式。

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

3.2.功能比较

功能 Nginx Apache
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流会分配一个新的线程管理。)
    Nginx详细介绍(并从技术层面深度剖析),Nginx,nginx,运维,linux,centos
  • 第二种方法就是I/O多路复用 (单个线程,通过记录跟踪每个I/O流(sock)的状态,来同时管理多个I/O流 );发明它的原因,是尽量多的提高服务器的吞吐能力。在同一个线程里面, 通过拨开关的方式,来同时传输多个I/O流
    Nginx详细介绍(并从技术层面深度剖析),Nginx,nginx,运维,linux,centos

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操作完成的方式。文章来源地址https://www.toymoban.com/news/detail-807890.html

到了这里,关于Nginx详细介绍(并从技术层面深度剖析)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 探秘开源隐语:架构深度剖析与隐私计算技术之旅

    隐语(SecretFlow)作为蚂蚁集团开源的可信隐私计算框架,其架构设计具有多层次的特点,虽然具体分层名称可能会根据实际描述略有差异,但我们可以依据已有的技术和信息对其进行结构化的拆解: 硬件层(或称TEE层/TCS层) : 这一层主要涉及到硬件层面的安全保障,尤其

    2024年04月17日
    浏览(37)
  • 决策树C4.5算法的技术深度剖析、实战解读

    在本篇深入探讨的文章中,我们全面分析了C4.5决策树算法,包括其核心原理、实现流程、实战案例,以及与其他流行决策树算法(如ID3、CART和Random Forests)的比较。 关注TechLead,分享AI全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦

    2024年02月08日
    浏览(35)
  • 【数据结构】 栈的深度剖析!超详细精解!

    🎥 屿小夏 : 个人主页 🔥个人专栏 : 数据结构解析 🌄 莫道桑榆晚,为霞尚满天! 什么是栈?栈这种数据结构有什么样的特性?它能够拿来干嘛?本文我们将深度探讨,剖析清楚栈的全部,你让熟练掌握栈的运用! ​ 栈是一种特殊的线性表,其只允许在固定的一端进行

    2024年02月08日
    浏览(31)
  • Nginx深度解析

    Nginx是一个开源的高性能Web服务器,广泛用于提供HTTP服务。 它以其高效能、稳定性和低资源消耗而闻名。 Nginx的核心特性 异步非阻塞事件驱动架构 :Nginx的主要优势之一是它的异步非阻塞处理方式,这使得它在处理大量并发连接时非常高效。 轻量级和高性能 :相比于其他

    2024年01月19日
    浏览(31)
  • 命令行启动nginx、停止nginx 、重启nginx详细教程

    1、按住shift键, 右键空白处, 打开powerShell窗口 如下: 2、输入启动 nginx指令 start nginx 屏幕会闪一个弹窗 再打开任务管理器 查看是否已有服务  有任务说明启动成功了 备注: 也可以双击nginx.exe 可以运行 但是这种方式容易造成 上次的nginx未关闭 服务中会有多个nginx服务 更新

    2024年02月12日
    浏览(33)
  • Nginx篇-Nginx详细安装教程

    Nginx是一款轻量级的 Web 服务器 、 反向代理服务器 及电子邮件(IMAP/POP3)代理服务器。 Web 服务器:通俗意义下的Web服务器可理解能处理静态资源,如html、css、js的服务器,其并发能力远高于应用服务器。 正向代理:通俗的讲就是Web服务器代替客户端去访问目标的服务器,此

    2024年02月16日
    浏览(31)
  • nginx(NGINX)详细下载安装及使用教程

    NGINX 是一个非常流行的开源 Web 服务器和反向代理服务器 ,它可以帮助用户负载均衡(主要体现在可以创建多个服务器,一般将静态资源页面和动态页面分开部署到不同服务器,这样就可以降低服务器压力)、缓存、反向代理、SSL 终止等功能,常用于 Web 应用程序的开发和部

    2024年04月26日
    浏览(29)
  • 【Linux】nginx基础篇 -- 介绍及yum安装nginx

    👨‍🎓 博主简介   🏅云计算领域优质创作者   🏅华为云开发者社区专家博主   🏅阿里云开发者社区专家博主 💊 交流社区: 运维交流社区 欢迎大家的加入! 🐋 希望大家多多支持,我们一起进步!😄 🎉如果文章对你有帮助的话,欢迎 点赞 👍🏻 评论 💬 收藏

    2024年02月08日
    浏览(33)
  • 【Nginx笔记01】Nginx配置文件介绍、反向代理、负载均衡

    这篇文章,主要介绍Nginx配置文件介绍、反向代理、负载均衡。 目录 一、nginx介绍 1.1、配置文件 1.2、反向代理 1.3、负载均衡 nginx配置文件是位于【conf】目录下的【nginx.conf】文件,这个文件中有三大部分组成,分别是:全局块、events块、http块。 全局块:定义一些全局变量,

    2023年04月23日
    浏览(32)
  • 深度详解Nginx正向代理与反向代理

    它的工作原理就像一个跳板,简单的说,我是一个用户,我访问不了某网站,但是我能访问一个代理服务器,这个代理服务器呢,他能访问那个我不能访问的网站,于是我先连上代理服务器,告诉他我需要那个无法访问网站的内容,代理服务器去取回来,然后返回给我,从网站的角度

    2024年02月11日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包