进程模型
worker进程
master进程模型核心函数ngx_master_process_cycle()中调用了创建子进程函数ngx_start_worker_processes(),该函数源码如下
static void
ngx_start_worker_processes(ngx_cycle_t *cycle, ngx_int_t n, ngx_int_t type)
{
ngx_int_t i;
ngx_channel_t ch;
ngx_log_error(NGX_LOG_NOTICE, cycle->log, 0, "start worker processes");
ch.command = NGX_CMD_OPEN_CHANNEL;
/
for (i = 0; i < n; i++) {
/*ngx_spawn_process方法调用fork函数创建进程执行ngx_worker_process_cycle()函数,该函数是worker进程模型的核心*/
ngx_spawn_process(cycle, ngx_worker_process_cycle,
(void *) (intptr_t) i, "worker process", type);
/*
在ngx_spawn_process创建好一个worker进程返回后,master进程就将worker进程的pid、worker
进程在ngx_processes数组中的位置及channel[0]传递给前面已经创建好的worker进程,然后继续
循环开始创建下一个worker进程。
*/
ch.pid = ngx_processes[ngx_process_slot].pid;
ch.slot = ngx_process_slot;
ch.fd = ngx_processes[ngx_process_slot].channel[0];
ngx_pass_open_channel(cycle, &ch);
}
}
在剖析ngx_worker_process_cycle是如何工作的之前我们了解master进程和worker进程之间的通信方式:master进程是监控进程,对worker进程监控和管理ÿ