Nginx及其架构设计
1.1. 什么是 Nginx
Nginx 是俄罗斯人编写的十分轻量级的 HTTP 服务器,Nginx,它的发音为“engine X”,是一个高性能的HTTP和反向代理服务器,同时也是一个 IMAP/POP3/SMTP 代理服务器。
Nginx 因为它的稳定性、丰富的模块库、灵活的配置和低系统资源的消耗而闻名.业界一致认为它是 Apache2.2+mod_proxy_balancer 的轻量级代替者,不仅是因为响应静态页面的速度非常快,而且它的模块数量达到 Apache 的近 2/3。对 proxy 和 rewrite 模块的支持很彻底,还支持 mod_fcgi、ssl、vhosts ,适合用来做 mongrel clusters 的前端 HTTP 响应。
目前Nginx在国内很多大型企业都有应用,且普及率呈逐年上升趋势。选择Nginx的理由也很简单:
第一,它可以支持5W高并发连接;
第二,内存消耗少;
第三,成本低。
1.2. Nginx在架构中发挥的作用
- 网关
---面向客户的总入口。
- 虚拟主机
---一台机器为不同的域名/ip/端口提供服务
- 路由
---使用反向代理,整合后续服务为一个完整业务
- 静态服务器
---mvvm模式中,用来发布前端html/css/js/img
- 负载集群
---使用upstream,负载多个tomcat
Nginx架构设计
2.1. Nginx的模块化设计
高度模块化的设计是 Nginx 的架构基础。Nginx 服务器被分解为多个模块,每个模块就是一个功能模块,只负责自身的功能,模块之间严格遵循“高内聚,低耦合”的原则。
- 核心模块
核心模块是 Nginx 服务器正常运行必不可少的模块,提供错误日志记录、配置文件解析、事件驱动机制、进程管理等核心功能。
- 标准 HTTP 模块
标准 HTTP 模块提供 HTTP 协议解析相关的功能,如:端口配置、网页编码设置、HTTP 响应头设置等。
- 可选 HTTP 模块
可选 HTTP 模块主要用于扩展标准的 HTTP 功能,让 Nginx 能处理一些特殊的服务,如:Flash 多媒体传输、解析 GeoIP 请求、SSL 支持等。
- 邮件服务模块
邮件服务模块主要用于支持 Nginx 的邮件服务,包括对 POP3 协议、IMAP 协议和 SMTP 协议的支持。
- 第三方模块
第三方模块是为了扩展 Nginx 服务器应用,完成开发者自定义功能,如:Json 支持、Lua 支持等。
2.2. Nginx多进程模型
2.1、服务器每当收到一个客户端时。就有服务器主进程(master process)生成一个子进程(worker process)出来和客户端建立连接进行交互,直到连接断开,该子进程结束。
2.2、使用进程的好处是各个进程之间相互独立,不需要加锁,减少了使用锁对性能造成影响,同时降低编程的复杂度,降低开发成本。
其次,采用独立的进程,可以让进程互相之间不会影响,如果一个进程发生异常退出时,其它进程正常工作,master 进程则很快启动新的 worker 进程,确保服务不中断,将风险降到最低。
缺点是操作系统生成一个子进程需要进行内存复制等操作,在资源和时间上会产生一定的开销;当有大量请求时,会导致系统性能下降。
2.3. Nginx的epoll模式
select和poll的处理模式如上图:
--在某一时刻,进程收集所有的连接,其实这100万连接中大部分是没有事件发生的。因此,如果每次收集事件时,都把这100万连接的套接字传给操作系统(这首先就是用户态内存到内核内存的大量复制),而由操作系统内核寻找这些链接上没有处理的事件,将会是巨大的浪费。
而epoll改进了收集连接的动作,提高效率。
epoll的优点:
² 支持一个进程打开大数目的socket描述符(FD)
² IO效率不随FD数目增加而线性下降
² 使用mmap加速内核与用户空间的消息传递
2.4. 正向代理与反向代理
4.1、代理:意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。
4.2、反向代理,服务端推出的一个代理招牌。
转载于:https://www.cnblogs.com/Soy-technology/p/11355597.html
Nginx及其架构设计相关推荐
- Nginx 核心架构设计
前言 最近在读 Nginx 相关的书籍,做一下读书笔记. Nginx 作为业界知名的高性能服务器,被广泛的应用.它的高性能正是由于其优秀的架构设计,其架构主要包括这几点:模块化设计.事件驱动架构.请求 ...
- 从 Nginx 优秀的核心架构设计,揭秘其为何能支持高并发?
作者:我最喜欢三大框架 https://my.oschina.net/u/3906190/blog/1859060 目录: 1. Nginx的整体架构 2. Nginx的模块化设计 3. Nginx的 ...
- 浅谈Nginx服务器的内部核心架构设计
前言 Nginx 是一个 免费的,开源的,高性能 的 HTTP 服务器和 反向代理,以及 IMAP / POP3 代理服务器. Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名 ...
- Nginx技术研究系列7-Azure环境中Nginx高可用性和部署架构设计
前几篇文章介绍了Nginx的应用.动态路由.配置.在实际生产环境部署时,我们需要同时考虑Nginx的高可用性和部署架构. Nginx自身不支持集群以保证自身的高可用性,商业版本的Nginx+推荐: T ...
- 架构设计:负载均衡层设计方案(3)——Nginx进阶
架构设计:负载均衡层设计方案(3)--Nginx进阶 请注明来源:http://blog.csdn.net/yinwenjie(未经允许严禁用于商业用途!) https://blog.csdn.net ...
- 阿里云域名解析网络和服务架构设计(四) 之阿里云ECS服务器Nginx代理实践
一.回顾 阿里云域名解析网络和服务架构设计总概览(一)_飞鸽FlyGo的博客-CSDN博客云解析DNS.负载均衡SLB.阿里云ECS服务器.阿里云ECS服务器Nginx代理https://flygo. ...
- 从Nginx优秀的核心架构设计,揭秘其为何能支持高并发
目录: Nginx的整体架构 Nginx的模块化设计 Nginx的请求方式处理 Nginx事件驱动模型 Nginx进程处理模型 Nginx简介 Nginx 是一个免费的,开源的,高性能HTTP 服务器 ...
- 欢迎来到美多商城!-项目准备之项目介绍-项目需求分析-项目架构设计
欢迎来到美多商城! [前后端不分离的项目] 项目介绍 项目需求分析 需求分析原因: 可以整体的了解项目的业务流程和主要的业务需求. 项目中,需求驱动开发.即开发人员需要以需求为目标来实现业务逻辑. 需 ...
- 千万级流量的大型分布式系统架构设计
本文是学习大型分布式网站架构的技术总结.对架构一个高性能.高可用.可伸缩及可扩展的分布式网站进行了概要性描述,并给出一个架构参考.文中一部分为读书笔记,一部分是个人经验总结,对大型分布式网站架构有较好 ...
最新文章
- [YTU]_2535 (Problem I: C++复数运算符重载(+与))
- 指向函数的指针--转
- jvm性能调优实战 -54Jetty NIO机制导致堆外内存溢出Direct buffer memory OOM
- 双十一临近,怎样让买家流畅地秒杀? ——腾讯WeTest独家开放电商产品压测服务
- 全球最强大脑在哪?阿里小蜜算法团队在寻找
- 2017年山东省ACM省赛总结
- 信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言——1112:最大值和最小值的差
- MIPS快速入门(原文+翻译):MIPS Architecture and Assembly Language Overview(持续更新中)
- Linux命令中正则表达式的运用
- linux-bash的基本-自动补全-快捷键-历史-命令的别名
- (转)Android属性动画完全解析(中),ValueAnimator和ObjectAnimator的高级用法
- 滴滴司机问我会 LRU 吗?
- 路由器截获微信消息_小白智慧微信小程序无法打印的解决方案
- 10.2. Incron - cron-like daemon which handles filesystem events
- Eclipse快捷键与使用技巧总结
- 进入linux jed文本编辑怎么退出,Linux文本编辑器Jed
- 手机微信桌面计算机不见了怎么办,微信桌面图标不见了怎么办
- JavaScript prototype原型实现继承
- 地图原点半径距离经纬度计算
- QAP,社会网络分析假设检验之一
热门文章
- 只能在执行 Render() 的过程中调用 RegisterForEventValidation
- [转载]Eclipse.ini的相关说明
- Codeforces Round #276 (Div. 2)
- linux find 反转 查找没有被找到的结果
- asp.net的cms 核心代码篇
- 苹果前置摄像头拍出来是反的怎么调_不用等了!屏下摄像头难攻克,明年还是挖孔屏...
- python需要音语基础_英语基础一般,如何才能学习C语言编程和Python
- python asyncio回调函数_最近用 Python 的 asyncio,有好多不懂。。
- 为什么要学python语言_我们为什么要学习Python语言?
- char怎么比较_C语言的 main 函数到底怎么写才是对的?