Nginx服务器的简明架构

Nginx模块介绍

Nginx内部由核心模块和其他功能模块组成。这种简单的结构分层,便于进行功能的扩展,也代码更加清晰易于维护。我们通常将其分为五大模块:核心模块,标准HTTP模块,可选HTTP模块,邮件服务模块和第三方模块。

核心模块

核心模块是程序运行所不可或缺的,它为Nginx提供了最基本的服务功能,比如权限控制、进程管理、日志操作等。

标准HTTP模块

作为HTTP服务器必须的标准功能模块,包括对HTTP的访问控制、基本认证、URL重写、负载均衡等。

可选HTTP模块

用于扩展标准的HTTP功能,比如常见的SSL加密、GeoIP、FLV处理。

邮件服务模块

实现了邮件服务器的代理功能,包含imap、pop3、smtp3种邮件协议的支持。

第三方模块

这个无须解释了吧,正是因为有了这功能才令Nginx显得异常强大。

架构一览

Nginx是基于事件驱动模型设计的,进程能够同时处理多个并发请求。它采用Master-Worker工作模式,启动过程如下:启动后会创建一个主进程,主进程负责监听外部请求,并将请求派发给Worker进程处理,Worker进程会将请求通过代理转发到后端服务器,由后端服务器进行处理。

Master进程

也叫监控进程,主要监听外部请求和管理Worker子进程,还有负责更换日志文件、配置读取、平滑升级等。

Worker进程

也叫工作进程,负责与后端服务器通信,接收处理结果,Cache和响应客户端请求。

请求处理

Nginx通常作为Web服务器使用,与客户端存在一对多的关系,这就要求它必须能够同时为多个客户端提供服务。那么Nginx处理请求的过程如何呢?

Nginx采用多进程机制(Master-Worker)和异步机制,每个Worker进程都使用异步非阻塞方式,可以同时处理多个请求。当某个Worker进程接收请求之后,调用IO进行处理,如果不能立即得到结果,就去优先处理其他的请求;而客户端在此期间也不用等待响应结果,能够去处理其他操作;当结果返回时,就会通知这个Worker进程,然后进行响应。

本文来自企鹅号 - 架构之美媒体

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏架构说

大流量Web系统性能优化实践

系统性能优化一般方法 1 通过工具寻找瓶颈 2 水平扩展机器 这遇到很多问题 分布式事务和cache问题等 需要调整架构和组件 ? ? ? ? ?...

3928
来自专栏社区的朋友们

TAF 必修课(五):Client 端调用

本节对 Taf-Client 如何发起远程调用进行解析,包括初始化过程、路由查询、以及目前支持的同步、异步和 Future 调用方式。

5620
来自专栏Java面试笔试题

什么是端口号

在网络技术中,端口(Port)包括逻辑端口和物理端口两种类型。物理端口指的是物理存在的端口,如ADSL Modem、集线器、交换机、路由器上用 于连接其他网络设...

701
来自专栏Golang语言社区

Golang语言--Coroutine可能存在的死锁

直接上代码: 1. 第一种情况, 如果没有select{}, main 主线程不会等待coroutine运行,导致coroutine得不到机会运行。 You ...

36310
来自专栏逸鹏说道

Mongodb中经常出现的错误 child process failed, exited with error number

异常处理汇总-服 务 器 http://www.cnblogs.com/dunitian/p/4522983.html 异常处理汇总-数据库系列 http:/...

3745
来自专栏大数据学习笔记

Struts2的Action是单例还是多例 / SpringMVC的controller默认是单例还是多例?

Struts2的Action是单例还是多例? Spring的controller默认是单例还是多例? 1、默认单例 SpringMVC默认是单例的。与Strut...

23810
来自专栏Java技术分享

Redis 在 SNS 类应用中的最佳实践有哪些?

2. 热点数据的实时缓存(比如feed,数据库、缓存同时写)

2039
来自专栏Clive的技术分享

PHP高并发大流量常规处理

增加服务器,提升服务器性能; nginx负载均衡; php、html静态化; 优化mysql,优化索引,mysql查询缓存; 引入redis、memcache;...

3556
来自专栏云知识学习

获取CDN或Nginx的用户真实ip地址

目前问题:腾讯云CDN作为前端,Apache作为后端的情况下,Apache只能获取到腾讯云CDN前端的ip地址,而无法获取到用户的真实ip地址,在这种情况下,后...

89112
来自专栏Python小屋

Python实现定时自动关闭的tkinter窗口

功能简要说明:程序运行后10秒钟自动关闭。 技术要点:tkinter应用程序的destroy()方法,多线程编程。 代码截图: ? 运行效果: ?

3106

扫码关注云+社区