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 条评论
登录 后参与评论

相关文章

来自专栏Laoqi's Linux运维专列

Linux防火墙-netfilter应用

iptables filter表小案例 : nat表应用 A机器两块网卡ens33(192.168.133.130)、ens37(192.168.100.1),...

3046
来自专栏Java技术

Nginx负载均衡实现tomcat集群方案简要小结

所谓tomcat集群,就是可以向外提供并行服务的多台机器,任何一台服务器宕机,其它服务器可以替代它向外提供服务,而不影响用户访问。

605
来自专栏LIN_ZONE

进程间通信的几种方式

注:本文参考操作系统课本,只是一些概念性的知识。 如需转载请注明出处:https://www.cnblogs.com/zhuchenglin/p/952219...

291
来自专栏运维小白

18.7 LVS介绍

LVS介绍 LVS是由国人章文嵩开发 流行度不亚于apache的httpd,基于TCP/IP做的路由和转发,稳定性和效率很高 LVS最新版本基于Linux内核2...

1828
来自专栏决胜机器学习

优化页面访问速度(三) ——服务端优化

服务端的优化,主要可以通过消息队列、减少数据库请求(缓存)、并发处理、页面静态化等方式处理。

762
来自专栏JAVA技术站

nginx简单的负载均衡配置

583
来自专栏北京马哥教育

Kubernetes框架概览

Kubernetes是什么 Kubernetes是互联网巨头Google推出的一款开源的容器集群管理工具。下面分别对这里面提到的概念做点解释: 容器 容器技术...

3146
来自专栏北京马哥教育

Nginx+FPM结构模型剖析及优化

随着php脚本语言使用的普及,目前webserice服务大部分都在用nginx+(php-fpm)的结构,了解了其工作过程后才可以在各个方面想办法做调整优化和故...

4026
来自专栏大闲人柴毛毛

架构高性能网站秘笈(四)——反向代理缓存

什么是反向代理? 在介绍“反向代理”之前,首先要介绍一下“正向代理”的概念。 1.什么是正向代理? 在NAT技术(Network Address Transla...

3418
来自专栏流柯技术学院

Tomcat性能调优方案

一、操作系统调优  对于操作系统优化来说,是尽可能的增大可使用的内存容量、提高CPU的频率,保证文件系统的读写速率等。经过压力测试验证,在并发连接很多的情况下,...

712

扫码关注云+社区