【云计算基础服务-Nginx WEB服务器---原理及简介详解】
文章目录
- 前言:
- 一、云计算基础服务-Nginx WEB服务器 详解
- 1、Nginx简介及原理
- 1.1 Nginx web简介
- 1.2 Nginx工作原理
前言:
本专栏专门讲解云计算服务基础知识,适合有一年Linux运维经验的云计算小白来学习,在这里你可以系统学习Nginx,Mysql,MyCat,Redis,Tomcate,JAVA服务器,JVM虚拟机,LNMP架构等相关内容,内容将由浅入深,陆续更新,专栏免费,欢迎订阅!!!有疑问欢迎评论区讨论。
一、云计算基础服务-Nginx WEB服务器 详解
1、Nginx简介及原理
1.1 Nginx web简介
- Nginx是一个高性能HTTP和反向代理服务器,IMAP、POP3、SMTP协议服务器。是由俄罗斯Rambler.ru站点开发的,具有极高的稳定性、丰富的功能集、示例配置文件和低系统资源消耗。
- 正是由于Nginx的高性能、轻量级,目前越来越多的互联网企业开始使用Nginx WEB服务器。
- Nginx相对于Apache优点如下:
- 高并发响应性能非常好,官方Nginx处理静态文件并发5w/s;
- 负载均衡及反向代理性能非常强
- 系统内存和CPU占用率特别低
- 可对后端服务进行健康检查
- 支持PHP cgi方式和FastCGI方式
- 可做为缓存服务器/邮件代理服务器
- 配置代码简洁且容易上手
1.2 Nginx工作原理
Nginx WEB 服务器最主要就是各种模块的工作,模块从结构上分为核心模块、基础模块和第三方模块,其中三类模块分别如下:
- 核心模块:HTTP模块、EVENT模块和MAIL模块等
- 基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块和HTTP Rewrite模块
- 第三方模块:HTTP Upstream Request Hash模块、Notice 模块和HTTP Access Key模块、Limit req模块、Limit req模块、Upstream check module等
Nginx 的模块从功能上分为如下类:
- Handlers(处理器模块):此类模块直接处理请求并进行输出内容和修改headers信息等操作,Handlers处理器模块一般只能有一个
- Filters(过滤器模块):此类模块主要对其他处理器模块输出的内容进行修改操作,最后由Nginx输出;
- Proxies(代理类模块):此类模块是Nginx的HTTP Upstream之类模块,这些模块主要与后端一些服务比如FasterCGI等进行交互,实现服务代理和负载均衡等功能。
Nginx的工作原理:
Nginx由Nginx内核和模块组成,其中内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过查找配置文件将客户端的请求映射到一个locationblock,而location是Nginx配置中的一个指令,用于访问的URL匹配,而在这个location中所配置的每个指令将会启动不同的模块去完成相应的工作。
Nginx的高并发得益于其采用了epoll模型,与传统模型的服务器架构不同,epoll是Linux内核2.6以后才出现的,Nginx采用epoll模型,异步非阻塞,而apache采用的是select模型:
- Select特点:select选择句柄的时候,是遍历了所有句柄,也就是说句柄有事件响应时,select需要遍历所有句柄才能获取到哪些句柄有事件通知,因此效率是非常低的。
- epoll的特点:epoll对于句柄事件的选择不是遍历的,是事件响应的,就是句柄上事件就马上选择出来,不需要遍历整个句柄链表,因此效率非常高。
Nginx默认以80端口监听在服务器上,并且启动一个master进程,同时由master进程生成多个工作进程,当浏览器发起一个HTTP请求,每个进程都可以处理这个连接,怎么做到的呢?怎么保证同一个时刻一个HTTP请求被一个工作机制处理呢。
首先每个worker进程都是从master进程fork(分叉)出来的 ,在master进程里建立好需要listen(listenfd) 之后,会fork出多个worker进程。
所有worker进程的listenfd会在新连接到来时变的可读,为保证只有一个进程处理该链接,所有worker进程在注册listenfd读事件前抢accept mutex,抢到互斥锁的那个进程注册listenfd读事件,在读事件里调用accept接受该链接。
当一个work进程在accept(接受)这个连接之后,就开始读取请求、解析请求、处理请求、产生数据后,在返回给客户端,最后断开连接,这样才是一个完整的请求流程。
【云计算基础服务-Nginx WEB服务器---原理及简介详解】相关推荐
- SAP UI5 初学者教程之二十六 - OData 服务配合 Mock 服务器的使用步骤详解试读版
一套适合 SAP UI5 初学者循序渐进的学习教程 教程目录 SAP UI5 本地开发环境的搭建 SAP UI5 初学者教程之一:Hello World SAP UI5 初学者教程之二:SAP UI5 ...
- 【华为云计算产品系列】eBackup云备份原理及实战详解
[华为云计算产品系列]eBackup云备份原理及实战详解 1. 基础概念 2. eBackup的组网方式 2.1. LAN-Base 2.2. LAN-Free 2.3. Server-Free 3. ...
- C++后端程序员必须彻底搞懂Nginx,从原理到实战详解
本文首先介绍 Nginx 的反向代理.负载均衡.动静分离和高可用的原理,随后详解 Nginx 的配置文件,最后通过实际案例实现 Nginx 反向代理和负载均衡的具体配置.学会 Nginx ,一篇足够了 ...
- nginx反向代理原理及配置详解
nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也是一个IMAP.POP3.SMTP代理服务器:nginx可以作为一个HTTP服务器进行网站的发布处理,另外 ...
- Web服务器——Apache相关内容详解
1.相关名词介绍 1)什么是Web服务器? Web服务器一般指网站服务器,是指驻留于因特网上某种类型计算机的程序,可以向浏览器等Web客户端提供文档, 也可以放置网站文件,让全世界浏览:可以放置数据文 ...
- web服务器常见配置搭建详解(超详细)
前言: 本博客借鉴一些写的比较好的博客,进行归纳总结,整理了一篇比较详细的服务器常见配置搭建教程 一来是和大家一起分享,二来也是作为自己的学习笔记记录一下. 温馨提示: 篇幅较长,请分阶段选择性查看. ...
- SAP UI5 应用开发教程之二十六 - OData 服务配合 Mock 服务器的使用步骤详解
从本教程 24 步骤开始,我们接触了 OData 模型.本地学习 SAP UI5 应用开发时,如果直接消费远端的 OData 服务,就会遇到跨域错误. 步骤 24 SAP UI5 初学者教程之二十四 ...
- 20个Nginx Web服务器最佳安全实践
0个Nginx Web服务器最佳安全实践 20个Nginx Web服务器最佳安全实践 Nginx 是一个轻量级,高性能的Web服务器/反向代理和电子邮件代理(IMAP/POP3),它可以运行在UNI ...
- 负载均衡原理与实践详解 第三篇 服务器负载均衡的基本概念-网络基础
负载均衡原理与实践详解 第三篇 服务器负载均衡的基本概念-网络基础 系列文章: 负载均衡详解第一篇:负载均衡的需求 负载均衡详解第二篇:服务器负载均衡的基本概念-网络基础 负载均衡详解第三篇:服务器负 ...
最新文章
- 常用数据增广方法,解决数据单一问题
- leetcode 279. 完全平方数 bfs广度优先解法 图解 动态规划解法 c代码
- WPF效果第一百七十八篇ItemsControl旋转
- Android之编程中存在性能影响的主要方面
- Generator执行步骤浅析
- VC2008 ATL控件 去掉运行库依赖
- 从零开始学前端:CSS背景颜色 --- 今天你学习了吗?(CSS:Day09)
- linux打包压缩文件并命名,linux下如何将文件打包、压缩并分割成制定大小
- php 时间戳 24小时制,如何在php中添加24小时的unix时间戳?(How do I add 24 hours to a unix timestamp in php?)...
- 微信小程序数据拼接_微信小程序数据处理
- 如何在iPhone上关闭“请勿打扰”
- 有一个已排好序的数组,要求输入一个数后,按原来排序规律将他插入数组。
- 详解C语言中的#define、#undef、#indef、#ifndef、#else、#endif,#if,#elif
- oracle的userenv和nls_lang详解
- npm 包管理器_纱包管理器:npm的改进
- CocosCreator H5 微信内置浏览器调起微信支付
- 《ASP.NET AJAX 应用剖析立即上手》推荐序!
- 海康机器人线激光立体相机获取体积测量开始时间点和结束测量时间点以及包裹四个顶角位置信息的可行办法
- Lucene6.6.0 案例与学习路线
- 台式计算机开机不自检不起动,台式电脑启动不了怎么办 电脑启动失败需要怎么排查...