nginx是一款轻量级的web服务器,相比较apache会占用更少的内存资源,并且采用异步非阻塞实现高并发请求,高度的模块化设计,模块编写清晰。
一、nginx功能分类:
按模块(主要包含4大模块):
1、CORE模块核心模块
2、EVENT模块事件模块
3、HTTP模块HTTP模块
4、MAIL模块邮件模块
按功能:
1、Handlers(处理器模块):此类模块直接处理请求。
2、Filters(过滤器模块):对处理器模块输出的内容进行过滤,有nginx输出。
3、Proxies(代理类模块):主要与后端的一些服务比如FastCGI等进行交互,实现服务代理和负载均衡等功能。
二、nginx模块结构(nginx的重点)
1、nginx的配置文件,先从配置文件中的一条命令说起,如:
server { listen 80; server_name www.xxxx.com; root /var/xxxx/www; location / { root /home/www; index index.php index.html index.htm; } }
2、nginx配置文件中的每一个命令,都会有ngx_comment_t结构体定义,如:root,root指令的定义(src/http/ngx_http_core_module.c 文件中)
{ ngx_string("root"), NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE1, ngx_http_core_root, NGX_HTTP_LOC_CONF_OFFSET, 0, NULL },
3、ngx_command_t 结构体定义(具体字段含义下面会讲到):
struct ngx_command_s { ngx_str_t name; ngx_uint_t type; char *(*set)(ngx_conf_t *cf, ngx_command_t *cmd, void *conf); ngx_uint_t conf; ngx_uint_t offset; void *post; };
4、ngx_module_t 模块结构体以及模块之间的关系
5、模块初始化过程
三、nginx进程模型
1、Master-Worker模型:
Master进程负责处理外部信号,同时管理所有的worker进程
Worker进程负责处理链接的建立、请求和相应
2、nginx启动过程
四、nginx事件模型
1、eventmodule数据结构
2、event数据结构
3、epoll_create&epoll_ctl添加监听事件
4、epoll_ctl添加http处理事件
五、nginx高并发原理
1、每个worker都是独立进程,不需要加锁,进程互不影响。 一般woker数目和cpu数目一致,减少因竞争cpu带来的上下文切换。
2、异步非阻塞。
3、epoll触发方式的理解
以上便是对nginx的模块,进程,事件,以及高并发的简单描述,后面会详细介绍没一个模块。