NGINX开篇
来源:互联网 发布:杜兰特2017总决赛数据 编辑:程序博客网 时间:2024/05/18 03:03
NGINX开篇
前言
最近空闲时间比较多, 开始阅读nginx源码, 阅读的过程总结和笔记整理了下, 汇集成了一个系列的文章, 由于nginx功能实在太多, 没法做到面面俱到, 只对已经阅读过的源码进行记录总结, 以后会逐步进行扩充.
源码版本
nginx1.6.2
源码目录
|-objs | |-src||-src| |-core | |-event | |-modules | |-http | |-modules | |-mail | |-misc | |-os | |-unix
1.objs目录是自动生成的一些源码的目录,执行完configure文件后会根据配置生成的源文件。
2.src/core目录中是nginx核心数据结构和算法,例如程序入口,配置文件解析,hash表,链表,红黑树等实现。
3.src/event目录是nginx事件处理部分,主要是网络事件,src/event/modules包含了各种不同的网络模型模块,根据不同系统配置,会自动选择一种最优的网络模型,select,poll,epoll等均有实现。
4.src/misc主要包含一个测试模块和google性能分析模块。
5.src/mail主要是邮件服务的模块。
6.src/os/unix主要是跟平台系统相关的一些函数的封装,保证上层接口的调用一致性。
7.src/http这里是nginx对http请求的具体处理部分,modules目录下包含各种http处理的模块过程,如果我们对nginx进行扩展的时候,一般都是添加到这个目录下。
启动过程
ngx_strerror_init 初始化错误信息,由于strerror调用非异步信号安全,因此nginx调用streeror获取所有系统错误信息,保存到一个数组中,以后直接根据错误号取数组中的错误信息。||Vngx_time_init 初始化程序中用到的时间,由于时间函数调用异常频繁,nginx对时间做了缓存,减少调用系统函数次数,提高效率。||Vngx_regex_init 初始化正则表达式库||Vngx_log_init 初始化日志文件目录||Vngx_init_cycle 初始化程序循环数据结构||V是否单进程模式 ------> 是 ------> ngx_single_process_cycle 单进程模式循环体| 1.初始化所有的注册模块| 2.for死循环调用ngx_process_events_and_timers函数,进行事件派发和处理。V否||Vngx_master_process_cycle 多进程或多线程模式循环体||Vsigprocmask重置一部分信号未阻塞模式,防止后面创建进程等操作产生信号中断,然后调用ngx_start_worker_processes创建进程,之后将所有信号重置为非阻塞,主进程进入||Vngx_start_worker_processes 根据事先配置好的进程数量循环调用ngx_spawn_process 创建进程。||Vngx_spawn_process 首先创建一个socket对,用于主进程和子进程之间的通信,然后调用fork创建进程,子进程调用回调函数prc,即ngx_worker_process_cycle。||Vngx_worker_process_cycle同样调用ngx_process_events_and_timers函数进行事件派发和处理。
nginx启动的大致流程, 启动过程中关于配置的解析过程相对比较复杂, 是一个递归调用, 比较难以理解, 后面的文章会讲解到.
NGINX(一)内存结构 : http://www.cnblogs.com/ourroad/p/4838794.html
NGINX(二)内存池 : http://www.cnblogs.com/ourroad/p/4838362.html
NGINX(三)HASH表 : http://www.cnblogs.com/ourroad/p/4844860.html
NGINX(四)配置解析 : http://www.cnblogs.com/ourroad/p/4861096.html
NGINX(五)模块 : http://www.cnblogs.com/ourroad/p/4861240.html
NGINX(六)扩展 : http://www.cnblogs.com/ourroad/p/4863051.html
NGINX(七)分段下载 : http://www.cnblogs.com/ourroad/p/4860477.html
- NGINX开篇
- nginx学习-开篇
- nginx源码分析之开篇
- nginx源码分析之开篇
- 开篇
- 开篇
- 开篇
- 开篇
- 开篇
- 开篇
- 开篇
- 开篇!
- 开篇
- 开篇!
- 开篇
- 开篇
- 开篇
- 开篇
- 矩阵分解的隐因子模型
- 基础篇:操作系统、计算机网络、设计模式(一)(附参考答案)
- Uva11383 二分图的完美匹配(深入理解KM算法)
- oracle数据库学习笔记(一)
- 计算机选课程序(C#实验)
- NGINX开篇
- 极角排序
- 论坛自动发帖原理介绍
- PTA数据结构 5-5 堆中的路径
- 关于docker包存储结构说明
- 【work】输出连续最多的字符
- Python编程中常用的12种基础知识总结
- BestCoder Round #54 (div.2) HDU5428 The Factor
- 字节流转换成字符流