Nginx进程模型
2014-08-15 13:25
232 查看
这篇主要是阅读http://simohayha.iteye.com/blog/467940这篇博文的笔记。、
nginx采用的也是大部分http服务器的做法,master,worker模型,基本的事件处理都是放在worker中,master负责一些全局初始化,以及对worker的管理。
nginx中的master和worker之间是通过socketpair来实现的,每次fork完一个子进程之后,将这个子进程的socketpair句柄传递给前面已经存在的子进程,这样子进程之间也就可以通信了。
nginx维护了一个ngx_processes数组用来存放所有的进程信息。fork主要是在ngx_spawn_process函数中进行的:主要包含三部分:1.寻找子进程的数组下标slot,2.创建socketpair并设置相关属性,3.在子进程中执行传递进来的函数。
子进程的管道可读事件捕捉函数是ngx_channel_handler(ngx_event_t *ev),在这个函数中,会读取message并解析。
在nginx中,worker和master的交互是通过流管道和信号,而master与外部的交互通过信号来进行。
master主循环之前,父子进程的信号处理函数相同,通过设置相应的标志变量,从而在主循环中,判断这些变量,做出相应的操作。
master主循环中除了sigsuspend(&set)这几句外,都是用if条件执行的代码。
worker主循环中主要是ngx_process_events_and_timers(cycle);这句,其它的也都是条件执行。
nginx采用的也是大部分http服务器的做法,master,worker模型,基本的事件处理都是放在worker中,master负责一些全局初始化,以及对worker的管理。
nginx中的master和worker之间是通过socketpair来实现的,每次fork完一个子进程之后,将这个子进程的socketpair句柄传递给前面已经存在的子进程,这样子进程之间也就可以通信了。
nginx维护了一个ngx_processes数组用来存放所有的进程信息。fork主要是在ngx_spawn_process函数中进行的:主要包含三部分:1.寻找子进程的数组下标slot,2.创建socketpair并设置相关属性,3.在子进程中执行传递进来的函数。
子进程的管道可读事件捕捉函数是ngx_channel_handler(ngx_event_t *ev),在这个函数中,会读取message并解析。
在nginx中,worker和master的交互是通过流管道和信号,而master与外部的交互通过信号来进行。
master主循环之前,父子进程的信号处理函数相同,通过设置相应的标志变量,从而在主循环中,判断这些变量,做出相应的操作。
master主循环中除了sigsuspend(&set)这几句外,都是用if条件执行的代码。
worker主循环中主要是ngx_process_events_and_timers(cycle);这句,其它的也都是条件执行。
相关文章推荐
- NginX进程模型-Cache Manager/Cache Loader
- 3-nginx进程模型
- nginx多进程模型之热部署
- Nginx的内部(进程)模型
- Nginx源码分析 ——Nginx的进程模型
- Nginx多进程并发连接处理模型
- nginx中的进程模型
- Nginx模块开发 —进程模型
- Nginx 进程模型
- Nginx学习之六-nginx核心进程模型
- nginx进程模型
- 【nginx】【转】Nginx核心进程模型
- Nginx的进程模型
- 图解Nginx-Nginx进程模型2
- nginx的进程模型
- Nginx进程模型(二)worker进程
- nginx源码分析--master和worker进程模型
- Nginx学习之六-nginx核心进程模型
- 文章12:初探Nginx架构之进程模型与事件处理机制
- Nginx进程模型(一)master进程