nginx源码分析--master和worker进程模型
一、Nginx整体架构
正常执行中的源码模nginx会有多个进程,其中最基本的源码模是master process(主进程)和worker process(工作进程),还可能包括cache相关进程。源码模
二、源码模核心进程模型
启动nginx的源码模macd改版指标源码主进程将充当监控进程,主进程通过fork()产生的源码模子进程则充当工作进程。
Nginx也支持单进程模型,源码模此时主进程即是源码模工作进程,不包含监控进程。源码模
核心进程模型框图如下:
master进程
监控进程作为整个进程组与用户的源码模交互接口,负责监护进程,源码模不处理网络事件,源码模不负责业务执行,源码模仅通过管理worker进程实现重启服务、源码模汤阴好的源码出售平滑升级、更换日志文件、配置文件实时生效等功能。
master进程通过sigsuspend()函数调用大部分时间处于挂起状态,直到接收到信号。
master进程通过检查7个标志位来决定ngx_master_process_cycle方法的运行:
sig_atomic_t ngx_reap;
sig_atomic_t ngx_terminate;
sig_atomic_t ngx_quit;
sig_atomic_t ngx_reconfigure;
sig_atomic_t ngx_reopen;
sig_atomic_t ngx_change_binary;
sig_atomic_t ngx_noaccept;
进程中接收到的信号对Nginx框架的意义:
还有一个标志位:ngx_restart,仅在master工作流程中作为标志位使用,与信号无关。
核心代码(ngx_process_cycle.c):
ngx_start_worker_processes函数:
worker进程
worker进程主要负责具体任务逻辑,主要关注与客户端或后端真实服务器之间的数据可读/可写等I/O交互事件,因此工作进程的阻塞点在select()、epoll_wait()等I/O多路复用函数调用处,等待数据可读/写事件。也可能被新收到的源码定制价格怎么算进程信号中断。
master进程如何通知worker进程进行某些工作?采用的是信号。
当收到信号时,信号处理函数ngx_signal_handler()会执行。
对于worker进程的工作方法ngx_worker_process_cycle,它主要关注4个全局标志位:
sig_atomic_t ngx_terminate;//强制关闭进程
sig_atomic_t ngx_quit;//优雅地关闭进程(有唯一一段代码会设置它,就是接受到QUIT信号。ngx_quit只有在首次设置为1时,才会将ngx_exiting置为1)
ngx_uint_t ngx_exiting;//退出进程标志位
sig_atomic_t ngx_reopen;//重新打开所有文件
其中ngx_terminate、ngx_quit、ngx_reopen都将由ngx_signal_handler根据接收到的信号来设置。ngx_exiting标志位仅由ngx_worker_cycle方法在退出时作为标志位使用。
核心代码(ngx_process_cycle.c):
源代码与模板的区别
源码:就是应用程序的源代码,里面含有程序代码和资源文件,里面就可能包含一些应用模板。最新印尼溯源码工厂
一般说模板,大多是指一些设计好的模板,比如一个网页的排版与布局,(复杂的模板里面可能还包含一些通用的JS脚本程序来实现一些收缩,隐藏之类的功能)。
Apache源代码全景分析:体系结构与核心模块目录
Apache源代码全景分析深入解析其体系结构和核心模块。首先,我们探讨第1章——Web服务器概述,它涵盖了Internet和WWW的基本概念,HTTP服务器的功能与工作方式,以及Apache服务器的主要特性,如虚拟主机、内容协商和动态内容生成。 第2章聚焦于Apache的太阳云储存源码下载体系结构,详细描述了Apache目录层次,包括操作系统支持层、可移植运行库层,以及核心功能层和可选功能层,阐述了Apache的启动流程,包括主程序main的结构和功能。 第3章探讨配置文件管理,阐述了Apache的配置系统,配置文件的分类和处理时机,以及指令的定义、参数和处理过程,还涵盖了.htaccess的使用和自定义配置段的实现。 第4章深入模块化体系结构,解释了模块的组成和交互,模块的加载方式,以及指令表、挂钩和模块与配置文件的关系。涵盖了各种常用模块,如缓存、安全和代理模块。 第5章讲解多任务并发处理,包括多进程和多线程模型,如MPM(Multi-Processing Modules)的数据结构和工作原理,以及WinNT MPM在处理网络连接中的应用。 第6章重点讲解网络连接,包括网络连接的处理流程,如等待连接、创建连接和数据读写,以及请求报文的解析。 第7章介绍过滤器,它们是Apache处理请求的重要组件,包括过滤器类型、结构和使用方法,以及智能过滤器的实现。 存储段和存储段组在第8章被详细解释,它们是Apache内存管理的关键部分,存储段的分配、操作以及与过滤器的交互都在这一章中阐述。 最后,第9章列举了一些常用过滤器,如输入和输出过滤器的特性和实现方法,为开发者提供了实际应用的参考。扩展资料
《Apache源代码全景分析:体系结构与核心模块》是由张中庆、梁雪平等编著的计算机应用技术类书籍;该书由电子工业出版社于年出版发行。书中详细介绍了Apache的基础体系结构和核心模块的实现机制,包括配置文件、模块化结构、多任务并发,以及网络连接和请求读取等知识。网站模板跟网站源码有什么区别?
网站源码通常分很多种,有动态的,有静态的,也有动静结合的,静态的网站源码可以直接打开使用,而动态的则需要配置相对应的web服务器才能使用。模板通常就包含在网站源码范围里面,因为只有包含大多数网站需要的功能,才会有网站模板,网站模板的意义就是给大多数网站使用,而不特定限于某一个网站使用。
网站源码与模版的关系就是:模板只是部分通用型网站前台源码的一小部分功能。这两者并不是同一个,而只是包含关系。
网站源码与模板及网站管理系统区别与关系
网站源码:
就是一个网站应用程序的源代码,里面含有程序代码和资源文件,里面就可能包含一些应用模板,如果这是一个网站管理系统,那么它就是网站管理系统的程序代码。
一般说模板,大多是指一些设计好的网页模板,比如一个网页的排版与布局,(复杂的模板里面可能还包含一些通用的JS脚本程序来实现一些收缩,隐藏之类的功能)。
网站管理系统,大多是指一些网站后台管理系统,就是比如你做了一个应用程序需要把程序发布出来,那么你要上传到网站服务器,这个时候就通过网站管理程序把你自己的应用(比如一个简单计时器等)上传到对应服务器中,别人才能通过这个服务器对外开放的网址访问你的应用。
2024-11-15 00:24
2024-11-15 00:22
2024-11-15 00:13
2024-11-14 23:27
2024-11-14 22:33