Nginx基本简述
一、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基本简述的更多相关文章
- Nginx 配置简述
不论是本地开发,还是远程到 Server 开发,还是给提供 demo 给人看效果,我们时常需要对 Nginx 做配置,Nginx 的配置项相当多,如果考虑性能配置起来会比较麻烦.不过,我们往往只是需要 ...
- nginx介绍(二) 架构篇
2. nginx架构总览 传统的基于进程或者基于线程的模型处理并发的方式都是为每个连接单独创建一个处理进程或线程,会在网络传输或者I/O操作上阻塞.而这对应用来说,在内存和 CPU的使用上效率都是非常 ...
- Nginx入门篇-基础知识与linux下安装操作
我们要深刻理解学习NG的原理与安装方法,要切合实际结合业务需求,应用场景进行灵活使用. 一.Nginx知识简述Nginx是一个高性能的HTTP服务器和反向代理服务器,也是一个 IMAP/POP3/SM ...
- web前端知识总结
前言: 一直想着整理一下关于前端的知识体系和资料,工作忙了些,挤挤总会有的,资料很多,就看你能不能耐下心坚持去学了,要多学多敲多想,祝你进步~ 学习之前首先要大概了解什么是HTML ,CSS , JS ...
- IT运维面试问题总结
IT运维面试总结如下,后期更新于:https://www.yuque.com/docs/share/d3dd1e8e-6828-4da7-9e30-6a4f45c6fa8e. 欢迎基于学习.交流目的的 ...
- 简述nginx(1)
Nginx能做什么 1.反向代理 2.负载均衡 3.HTTP服务器(包含动静分离) 4.正向代理 反向代理 反向代理应该是Nginx做的最多的一件事了,什么是反向代理呢,以下是百度百科的说法:反向代理 ...
- 简述systemd的新特性及unit常见类型分析、使用systemd管理编译安装的nginx
1. systemd新特性 并行处理(同时启动)所有服务. 基于依赖关系定义的服务控制逻辑 系统状态快照 按需激活进程,只有第一次被访问时才会真正启动: 2. systemd的常见unit类型 Ser ...
- nginx 集群简述
1.负载均衡介绍: 负载均衡是由多台服务器以对称的方式组成一个服务器集合,每台服务器都具有等价的地位,都可以单独对外提供服务而无须其他服务器的辅助.其工作模式为将外部发送来的请求均匀分配到对称结构中的 ...
- SSL交互简述及nginx双向认证配置
一.证书生成. 1.SSL Server生成私钥/公钥对.server.key(加密)/server.pub(解密):2.server.pub生成请求文件server.csr,包含server的一些信 ...
随机推荐
- day 14 C语言strcmp()函数:比较两个字符串
(1).下列关于C语言文件的叙述中正确的是[C] (A).文件由一系列数据依次排列组成,只能构成二进制文件 (B).文件由结结构序列组成,可以构成二进制文件或文本文件 (C).文件由数据序列组成,可以 ...
- F2BPM的流程仿真
仿真概述 F2BPM工作流仿真是一种通过建立工作流虚拟运行环境执行工作流仿真的方法.集中式仿真引擎解释工作流仿真模型,仿真活动的执行,处理仿真过程中的不确定性,从而完成工作流模型的仿真.同时,会实时显 ...
- java类的反射机制
1.获得一个类的类对象有哪些方式? - 方法1:类型.class,例如:String.class- 方法2:对象.getClass(),例如:"hello".getClass()- ...
- Go 变量及基本数据类型3
#### Go 变量及基本数据类型(三)今天学习一下剩下的两个基本数据类型(布尔类型,字符串类型)以及基本数据类型的相互转换##### 布尔类型布尔类型也称为bool 类型, bool 类型只允许取值 ...
- chapter2 线性回归实现
1 导入包 import numpy as np 2 初始化模型参数 ### 初始化模型参数 def initialize_params(dims): w = np.zeros((dims, 1)) ...
- Typora + picgo + Chevereto 优雅地上传图片
需求:由于经常使用typora写文章,但是配合picgo使用的sm.ms图床,github图床等,速度不稳定,因此我们想要利用自己的服务器搭建自己的图床,将自己文章的图片上传到自己的服务器中,优雅地写 ...
- pod 详解
静态pod是由kubelet进行管理的仅存在于特定的node上的pod. pod容器共享volume同一个pod中的多个容器能够共享pod级别的存储卷volume pod的配置管理 应用配置管理方案 ...
- 1.kafka
什么是Kafka 1.Apache Kafka是一个开源消息系统,由Scala写成. 2.Kafka是一个分布式消息队列.Kafka对消息保存时根据Topic进行归类,发送消息者称为Producer ...
- 入门 - 复习Kubernetes核心概念 (八)
本文将会简单介绍Kubernetes的核心概念.因为这些定义可以在Kubernetes的文档中找到,所以文章也会避免用大段的枯燥的文字介绍.相反,我们会使用一些图表(其中一些是动画)和示例来解释这些概 ...
- curl 查看接口的网络分段响应时间
示例如下 curl -o /dev/null -s -w %{time_namelookup}::%{time_connect}::%{time_starttransfer}::%{time_tota ...