前言

最近空闲时间比较多, 开始阅读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获取所有系统错误信息,保存到一个数组中,以后直接根据错误号取数组中的错误信息。
|
|
V
ngx_time_init 初始化程序中用到的时间,由于时间函数调用异常频繁,nginx对时间做了缓存,减少调用系统函数次数,提高效率。
|
|
V
ngx_regex_init 初始化正则表达式库
|
|
V
ngx_log_init 初始化日志文件目录
|
|
V
ngx_init_cycle 初始化程序循环数据结构
|
|
V
是否单进程模式 ------> 是 ------> ngx_single_process_cycle 单进程模式循环体
| 1.初始化所有的注册模块
| 2.for死循环调用ngx_process_events_and_timers函数,进行事件派发和处理。
V

|
|
V
ngx_master_process_cycle 多进程或多线程模式循环体
|
|
V
sigprocmask重置一部分信号未阻塞模式,防止后面创建进程等操作产生信号中断,然后调用ngx_start_worker_processes创建进程,之后将所有信号重置为非阻塞,主进程进入
|
|
V
ngx_start_worker_processes 根据事先配置好的进程数量循环调用ngx_spawn_process 创建进程。
|
|
V
ngx_spawn_process 首先创建一个socket对,用于主进程和子进程之间的通信,然后调用fork创建进程,子进程调用回调函数prc,即ngx_worker_process_cycle。
|
|
V
ngx_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开篇的更多相关文章

  1. nginx+iis实现负载均衡

    最近在研究分布式系统架构方面的知识,包括负载均衡,数据库读写分离,分布式缓存redis等.本篇先从负载均衡服务架构入手,关于负载均衡百度百科的定义如下:负载均衡,英文名称为Load Balance,其 ...

  2. centos 系统下安装FastDFS+nginx+fastdfs-nginx-module安装配置

    前言: 以前的项目上传的文件都是保存到本地或者是局域网内的共享文件夹下,由于数据量,服务器的负载均衡(分机的某些图片无法访问的问题处理)等因素的情况下,就想到用fastdfs来文件管理,花了几天时间硬 ...

  3. 【转】nginx+iis实现负载均衡

    最近在研究分布式系统架构方面的知识,包括负载均衡,数据库读写分离,分布式缓存redis等.本篇先从负载均衡服务架构入手,关于负载均衡百度百科的定义如下:负载均衡,英文名称为Load Balance,其 ...

  4. Nginx之旅系列 - Nginx日志功能 PK Linux内核printk

    题记:Nginx之旅系列是用来记录Nginx从使用到源码学习的点点滴滴,分享学习Nginx的快乐 Nginx 首页: http://nginx.org/ Nginx日志功能 PK Linux内核pri ...

  5. client,server,nginx 在使用keepAlive 专题

    2. TCP keepalive overview In order to understand what TCP keepalive (which we will just call keepali ...

  6. .NET Core IdentityServer4实战-开篇介绍与规划

    一.开篇寄语 由于假期的无聊,我决定了一个非常有挑战性的活动,也就是在年假给大家带来一个基于OAuth 2.0的身份授权框架,它就是 IdentityServer4 ,如果没有意外的话,一定可以顺利的 ...

  7. 我为什么要谈KeepAlive(文末增加nginx 负载tcp长连接保持 demo)

    http://blog.sina.com.cn/s/blog_e59371cc0102ux5w.html 最近工作中遇到一个问题,想把它记录下来,场景是这样的: 从上图可以看出,用户通过Client访 ...

  8. Java网络编程和NIO详解开篇:Java网络编程基础

    Java网络编程和NIO详解开篇:Java网络编程基础 计算机网络编程基础 转自:https://mp.weixin.qq.com/s/XXMz5uAFSsPdg38bth2jAA 我们是幸运的,因为 ...

  9. leveldb开篇

    因为工作的需求,最近看了一些项目的源码,包括nginx.tair.leveldb,一直看了下来都没有写东西的习惯,虽然作了不少记录,但都是只有自己才能看懂的笔记. 好多次都说开始写blog,锻炼一下自 ...

随机推荐

  1. 基于Vuforia的Hololens图像识别

    微软官方Hololens开发文档中有关于Vuforia的内容,https://developer.microsoft.com/en-us/windows/holographic/getting_sta ...

  2. MyISAM读写并发优化

    MyISAM在读操作占主导的情况下是很高效的.可一旦出现大量的读写并发,同InnoDB相比,MyISAM的效率就会直线下降,而 且,MyISAM和InnoDB的数据存储方式也有显著不同:通常,在MyI ...

  3. BZOJ3404: [Usaco2009 Open]Cow Digit Game又见数字游戏

    3404: [Usaco2009 Open]Cow Digit Game又见数字游戏 Time Limit: 3 Sec  Memory Limit: 128 MBSubmit: 47  Solved ...

  4. [转载]js javascript 判断字符串是否包含某字符串,String对象中查找子字符,indexOf

    var Cts = "bblText"; if(Cts.indexOf("Text") > 0 ) { alert('Cts中包含Text字符串'); }

  5. leetcode 练习1 two sum

    leetcode 练习1  two sum whowhoha@outlook.com 问题描述 Given an array of integers, return indices of the tw ...

  6. uva 125

    floyd 算法   如果存在无数条路  则存在a->a的路  a->b的路径数等于 a->i 和 i->b(0=<i<=_max) 路径数的乘积和 #includ ...

  7. vc2008程序发布指南

    vc2008程序发布指南 2008-05-03 17:46 vc2008开发的程序的发布方式可以有5种方式: 1. 采用静态链接到crt和MFC. 只要你拥有组成程序的所有源代码,你就可以采用这种方式 ...

  8. SDUT2190救基友记1

    http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2190 思路 : 这个题,一开始以为是博弈,以为 ...

  9. SQLite入门与分析(二)---设计与概念(续)

    SQLite入门与分析(二)---设计与概念(续)   写在前面:本节讨论事务,事务是DBMS最核心的技术之一.在计算机科学史上,有三位科学家因在数据库领域的成就而获ACM图灵奖,而其中之一Jim G ...

  10. Agri Net POJ1258 && Constructing Roads POJ2421

    题意,在给出的图中,使用最小花费的边,使这个图仍然连通. #include <cstdio> #include <algorithm> #include <cstring ...