一、Nginx简介

Nginx是一个开源且高性能、可靠的HTTP中间件、代理服务.

开源:直接获取源代码

高性能:支持海量高并发

1、nginx应用场景:

静态处理   (对静态页面的处理,不管是httpd还是nginx默认只能处理静态页面)

反向代理   (不直接处理客户端请求,而是将请求转交给其它服务器)

负载均衡   (长跟反向代理相结合,负责将客户端的请求转交给其它压力较小的服务器)

资源缓存  (对客户端经常访问的数据进行缓存,从而加快客户端的访问速度)

安全防护  (nginx对自己本身有一定防护措施)

访问限制   (有点类似于apache的order  deny,allow)

访问认证   (对所访问网站,进行添加用户名和密码)

单apache:同时处理客户端的理想值是2w

单nginx: 同时处理客户端的理想值是5w

nginx是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务.众所周知nginx相比于Apache有更高的并发,可以接收处理更多的访问请求,这得益于IO模型,下面为大家介绍IO模型

二、I/O模型介绍

每次I/O,都要经由两个阶段

第一步:将数据从磁盘文件先加载至内核空间(缓冲区),等待数据准备完成,时间较长

第二步:将数据从内核缓存区复制到用户空间的进程的内存中,时间较短

3、同步异步,阻塞和非阻塞

同步异步的区别:

    同步 : 被调用者不会返回任务的状态,需要调用者不停询问

    异步 : 被调用者会向调用者返回任务的状态,不需要调用者不停询问

 

IO多路复用(select,epoll),异步阻塞

用户进程找一个代理select,而不直接与内核打交道,系统调用交于select进行处理。

用户进程收到资源从磁盘写入内核缓冲区信息后,将内核缓冲区内容复制到用户空间。

select接待用户进程不是一对一的方式,而是一对多。用户进程依旧阻塞于select调用。这个有点像吃饭,客人和服务员之间的关系,>客人不会和后厨打交道,交由服务员完成。

IO多路复用只能成为异步阻塞模型,因阻塞在IO调用那里,但一个select可以检测多个IO模型,相比与同步阻塞只能检测一个提高了cpu的利用率。

信号驱动型     (异步半阻塞)Apache

即用户进程建立SIGIO的信号处理程序,复制数据从磁盘到内核空间,等处理完递交SIGIO告知用户进程,这个过程是不阻塞的状态。

用户进程从内核空间复制到用户应用空间,这个过程是阻塞的。

信号驱动并未完全解决问题,只是做到了一部分不阻塞,一部分阻塞。

异步IO模型 (异步非阻塞)   Nginx

用户进程不受阻塞,所有的请求,拿数据拷贝到应用空间都由内核完成,用户进程可以接收更多的用户请求.

三、高并发原理

nginx高并发使用的是epoll的方式,提供给用户访问,复制数据的一些操作交由内核完成.自身做的事情越少接待的用户请求就越多.

epoll在linux2.6中增加了内存拷贝mmap机制,加速与内核空间的消息传递,既内存映射.

内存映射机制:磁盘中有数据,数据有对应的inode号,在内存中映射一个相同的inode好,大小也相同,下次拿数据不需要遍历inode号,分析路径了,这样提高了效率.

select 缺点

1. 能够监视文件描述符的数量存在最大机制

2. 线程遍历扫描效率低下

epool 模型

1. 每当FD就绪,采用系统的回调函数直接将FD放入,效率更高

2. 最大连接无限制

CPU亲和(affinity)

将CPU核⼼和Nginx⼯作进程绑定⽅式,把每个worker进程固定在⼀个cpu上执⾏,减少切换cpu 的 cache miss ,获得更好的性能。

sendfile

传统⽂件传输, 在实现上其实是⽐较复杂的, 其具体流程细节如下:

1.调⽤read函数,⽂件数据被复制到内核缓冲

2.read函数返回,⽂件数据从内核缓冲区复制到⽤户缓冲区

3.write函数调⽤,将⽂件数据从⽤户缓冲区复制到内核与socket相关的缓冲区。

4.数据从socket缓冲区复制到相关协议引擎。

传统⽂件传输数据实际上是经过了四次复制操作:

硬盘—>内核buf—>⽤户buf—>socket缓冲区(内核)—>协议引擎

也就是说传统的⽂件传输需要经过多次上下⽂的切换才能完成拷贝或读取,

 

Nginx基本简述的更多相关文章

  1. Nginx 配置简述

    不论是本地开发,还是远程到 Server 开发,还是给提供 demo 给人看效果,我们时常需要对 Nginx 做配置,Nginx 的配置项相当多,如果考虑性能配置起来会比较麻烦.不过,我们往往只是需要 ...

  2. nginx介绍(二) 架构篇

    2. nginx架构总览 传统的基于进程或者基于线程的模型处理并发的方式都是为每个连接单独创建一个处理进程或线程,会在网络传输或者I/O操作上阻塞.而这对应用来说,在内存和 CPU的使用上效率都是非常 ...

  3. Nginx入门篇-基础知识与linux下安装操作

    我们要深刻理解学习NG的原理与安装方法,要切合实际结合业务需求,应用场景进行灵活使用. 一.Nginx知识简述Nginx是一个高性能的HTTP服务器和反向代理服务器,也是一个 IMAP/POP3/SM ...

  4. web前端知识总结

    前言: 一直想着整理一下关于前端的知识体系和资料,工作忙了些,挤挤总会有的,资料很多,就看你能不能耐下心坚持去学了,要多学多敲多想,祝你进步~ 学习之前首先要大概了解什么是HTML ,CSS , JS ...

  5. IT运维面试问题总结

    IT运维面试总结如下,后期更新于:https://www.yuque.com/docs/share/d3dd1e8e-6828-4da7-9e30-6a4f45c6fa8e. 欢迎基于学习.交流目的的 ...

  6. 简述nginx(1)

    Nginx能做什么 1.反向代理 2.负载均衡 3.HTTP服务器(包含动静分离) 4.正向代理 反向代理 反向代理应该是Nginx做的最多的一件事了,什么是反向代理呢,以下是百度百科的说法:反向代理 ...

  7. 简述systemd的新特性及unit常见类型分析、使用systemd管理编译安装的nginx

    1. systemd新特性 并行处理(同时启动)所有服务. 基于依赖关系定义的服务控制逻辑 系统状态快照 按需激活进程,只有第一次被访问时才会真正启动: 2. systemd的常见unit类型 Ser ...

  8. nginx 集群简述

    1.负载均衡介绍: 负载均衡是由多台服务器以对称的方式组成一个服务器集合,每台服务器都具有等价的地位,都可以单独对外提供服务而无须其他服务器的辅助.其工作模式为将外部发送来的请求均匀分配到对称结构中的 ...

  9. SSL交互简述及nginx双向认证配置

    一.证书生成. 1.SSL Server生成私钥/公钥对.server.key(加密)/server.pub(解密):2.server.pub生成请求文件server.csr,包含server的一些信 ...

随机推荐

  1. AGC041F Histogram Rooks

    有生之年自己做出了一个 AGC F 还踩了标算,但是好像在我之前已经有人踩过标算了,再鞭尸一波也无可厚非 hhh 看到"全部被覆盖" 条件不好做,考虑容斥,即选择若干个位置强制它们 ...

  2. elasticsearch拼写纠错之Term Suggester

    一.什么是拼写纠错 拼写纠错就是搜索引擎可以智能的感知用户输入关键字的错误,并使用纠正过的关键字进行搜索展示给用户:拼写纠错是一种改善用户体验的功能: elasticsearch提供了以下不同类型的s ...

  3. 刚进公司,不懂GIt工作流的我瑟瑟发抖

    前言 不懂git工作流,被辞退了! 之前在看到这句话的时候,我刚实习入职不久,瑟瑟发抖.好巧不巧,今天又看到了类似的文章讲git重要性的. 眼下,学校导师安排给我的课题组了一个新的工程项目,使用git ...

  4. c#操作符详解

    操作符概览 操作符(Operator)也译为"运算符" 操作符是用来操作数据的,被操作符操作的数据称为操作数(Operand) 操作符的本质 操作符的本质是函数(即算法)的&quo ...

  5. T-SQL的存储过程

    1.简介 存储过程可以说是一个记录集,它是由一些T-SQL语句组成的代码块,这些T-SQL语句代码像一个方法一样实现一些功能(对单表或多表的增删改查),然后再给这个代码块取一个名字,在用到这个功能的时 ...

  6. vue学习17-插槽作用域

    <!DOCTYPE html> <html lang='en'> <head> <meta charset='UTF-8'> <meta http ...

  7. centos7 service iptables save 报错

    解决办法: 1.systemctl stop firewalld 2.yum install iptables-services 3.systemctl  restart iptables 4.ser ...

  8. JVM之栈、堆、方法区(三)

    一.CPU和内存的交互 今天除夕,祝大家新年快乐,其实,我们知道的,我们的CPU跟内存会有非常频繁的交互,因为如果这个频繁的交互是交给我们的磁盘的话,那么随着我们的CPU运转速度越来越快,那么我们的磁 ...

  9. HTML 基础1

    HTML 超文本标记语言 文件后缀html,htm 标签成对出现:开始标签--结束标签 元素内容位于开始标签--结束标签之间(可以有空内容) 空元素<a/> 大小写不敏感 元素,属性 &l ...

  10. vue组件中使用<transition></transition>标签过渡动画

    直接上代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...