文档章节

nginx源码分析之开篇

那一剑的风情
 那一剑的风情
发布于 2012/09/18 16:58
字数 936
阅读 10181
收藏 149
点赞 4
评论 14

nginx源码构思精巧,每每阅读颇有收获,写此文与各码农分享

阅读从main开始,流程非常清晰

/* 系统错误初始化,将构建ngx_sys_errlist */

ngx_strerror_init();

/* 选项处理 */
ngx_get_options(argc, argv);

/* 时间初始化, 当前时间:ngx_current_msec */
ngx_time_init();

/* 日志初始化 */
log = ngx_log_init(ngx_prefix);

/* 选项处理 */
ngx_save_argv(..., argc, argv);
ngx_process_options(...);

/* 操作系统初始化处理 */
ngx_os_init(log);

/* 模块点名, ngx_modules代表所有模块,是个数组 */
ngx_max_module = 0;
for (i = 0; ngx_modules[i]; i++) {
    ngx_modules[i]->index = ngx_max_module++;
}

/*
 * 系统初始化,这里将发生配置文件解析,模块上下文注册钩子调用,模块初始化
 * module     : 模块
 * commands  : 模块指令集,负责解析配置文件的选项,一个指令对应一个配置选项
 * conf            : 模块配置结构体,指令解析后的值就是存储在这个里面,每个模块都有自已的一个conf
 * ctx              : 模块上下文,有四种,core, event, http, mail,有注册钩子功能。比如 create conf, init conf
 */
cycle = ngx_init_cycle(&init_cycle);

/* 创建进程id文件 */
ngx_create_pidfile(&ccf->pid, cycle->log);

/*
 * 进程处理
 * 主进程(master)产生多个工作进程(worker)
 * 这里将做各模块进程初始化,监听,接受,请求处理,还有信号等
 */
ngx_master_process_cycle(cycle) {
    ngx_start_worker_processes(cycle, ccf->worker_processes,
                               NGX_PROCESS_RESPAWN) {
        for ( ... ) {
            ngx_spawn_process(cycle, ngx_worker_process_cycle, NULL,
                          "worker process", type);
        }
    }
}


goto: 继续
/* 生产进程都在这个函数里处理 */
ngx_worker_process_cycle {
    /* 各模块进程注册钩子调用 */
    ngx_worker_process_init();
   
    for ( ;; ) {
        ngx_process_events_and_timers(cycle);
    }
}
   

goto: 继续
ngx_process_events_and_timers(cycle) {
    /*
     * 定时器,用红黑树实现,这里找出某个event(事件)的超时时间
     * 每个事件在红黑树里的key的值为:ngx_currnet_msec + 超时时间(默认60s)
     * timer的值为 -1 (如果没有事件),或 ngx_current_msec - key
     */
    timer = ngx_event_find_timer();

    /* epoll 机制,这里将做 epoll_wait(..., timer); */
    ngx_process_events(cycle, timer, flags);
   
    /* 先处理所有可能超时的事件,如果超时,将event的timedout设为1,并且马上event->handler(ev); */
    ngx_event_expire_timers();

    /* 事件存队列方式,开始遍历,调用 */
    ngx_event_process_posted(cycle, &ngx_posted_events);
}


/*
 * 几个重要的结构体
 * ngx_listening_t       : 监听套接字的结构体,比如地址,端口等
 * ngx_connection_t   : 每个socket将对应一个connection,意为连接,里面存着 fd,read(读事件),
 *                               write(写事件) 等。
 * ngx_event_t    : 事件结构体,有个重要的函数指针handler,fd事件被驱动时,将调用这个函数。
 *                               它有几个重要成员
 *                                     timer_set  : 每个event在epoll_wait前,要先进入定时器红黑树,这个标记就是
 *                                                       标记是否在定时器里, 超时处理用的.
 *                                     active       : 当ngx_add_event里(添加或更新事件) 进入epoll时,会置为1.
 *                                     ready       : 进入事件队列里,将置为1,只有为1,它对应的socket fd才可以读
 *                                     timedout   : 此事件对应的socket fd将视为超时
 */


/*
 * http处理
 * 当 listen fd 有连接过来时,它将调用函数 ngx_http_init_connection
 * 当 accept fd 有传送东东时,它将调用函数 ngx_http_init_request,所以的处理都将从这函数开始
 */
ngx_http_init_request {
    ngx_http_process_request_line {
        /* 读请求头 */
        ngx_http_read_request_header(...);

        /* 解析请求行 */
        ngx_http_parse_request_line(...);

        /* 处理请求头部信息 */
        ngx_http_process_request_headers(...) {
            for ( ;; ) {
                /* 解析每一行 */
                ngx_http_parse_header_line(...);
            }

            /* 解析之后对所有行的处理 */
            ngx_http_process_request_header(...);

            /* 真正开始处理请求 */
            ngx_http_process_request(r) {
                ngx_http_handler(r) {
                    /* 非常巧妙的设计处理即将开始 */
                    ngx_http_core_run_phases(r);
                }
            }
        }

    }
}


/*
 * 精巧的设计函数:责任链模式
 * http的每个请求可以分为好几个阶段
 *        规则重写(rewrite)
 *        处理配置(不同url有不同的配置)
 *        权限访问处理
 *        核心内容处理(是走fastcgi,还是直接输出或从缓存获取等)
 *        日志处理
 *
 * 每个阶段都可以由好几个模块处理,这些模块组成一个链,
 * 这是设计模式里的一种,责任链模式
 */
 ngx_http_core_run_phases(r) {
    while (ph[r->phase_handler].checker) {

        rc = ph[r->phase_handler].checker(r, &ph[r->phase_handler]);

        if (rc == NGX_OK) {
            return;
        }
    }
 }


 此文全完,阅读原文:http://nglua.com/reads/1.html

© 著作权归作者所有

共有 人打赏支持
那一剑的风情

那一剑的风情

粉丝 119
博文 20
码字总数 21879
作品 0
厦门
程序员
加载中

评论(14)

KennyLonng
KennyLonng
希望有点整体结构或者设计的东西
RyaneLuo
RyaneLuo
最好画点图,代码逐行看,大部分程序员都懂。
但是代码背后,使用的设计和思维方式,则不是每个人都能理出一个头绪来。
ThinkingT
ThinkingT
我也是大概研究一下nginx 跟楼主的一样

可能还没有仔细的研究 等有时间 仔细研究
希望和大家多交流
高天
高天
坚持下去,goodluck
刘畅1987
刘畅1987
//这里有NGINX 的日志分割的操作
http://firefrog.sinaapp.com/?p=358
nbl_cs
nbl_cs
关注
Leo進城務工
Leo進城務工
保持关注
SunnyGo
SunnyGo
Apache的日志拆分也靠的是第三方软件
雄起
牛B
x
xewn
@haitao 你说的这些问题,早就不是问题了,希望你还是再深入了解下。
官方不支持,也有第三方的嘛,实在不合适,就自己写一个模块,都很容易么。
nginx源码分析—启动流程

作者:阿波 本文链接:http://blog.csdn.net/livelylittlefish/article/details/7243718 Content 0. 序 1. main()分析 2. 注意问题 2.1 几个初值 2.2 nginx工作模式 2.3 一些配置 2.4 其他开...

晨曦之光
2012/03/09
1K
0
Nginx 单元测试自动化浅析之一-Test::Nginx源码分析和使用

http://www.taobaotest.com/blogs/2433 主题 Nginx 源码分析 单元测试 Nginx 单元测试自动化浅析之一 -Test::Nginx 源码分析和使用 Test::Nginx 是用来进行 Nginx 测试的一个 perl 语言的框架...

年少爱追梦
2016/12/04
54
0
nginx源码分析—hash结构ngx_hash_t(v1.0.4)

本博客(http://blog.csdn.net/livelylittlefish )贴出作者(阿波)相关研究、学习内容所做的笔记,欢迎广大朋友指正! Content 0.序 1.hash结构 1.1ngxhasht结构 1.2ngxhashinit_t结构 1....

晨曦之光
2012/03/09
673
0
阿里架构师的成长之路,Java开发者的技术梦要如何实现

写在开篇: 提升技术的误区: 有人认为想成为技术大牛最简单直接、快速有效的方式是“拜团队技术大牛为师”,让他们平时给你开小灶,给你分配一些有难度的任务。 有这种想法是错误的,主要有...

java进阶
04/18
0
0
nginx源码分析—链表结构ngx_list_t

本博客(http://blog.csdn.net/livelylittlefish )贴出作者(阿波)相关研究、学习内容所做的笔记,欢迎广大朋友指正! Content 1.链表结构 1.2 ngxlistt的逻辑结构 2.1创建链表 3.一个例子...

晨曦之光
2012/03/09
204
0
nginx源码分析—数组结构ngx_array_t

本博客(http://blog.csdn.net/livelylittlefish )贴出作者(阿波)相关研究、学习内容所做的笔记,欢迎广大朋友指正! Content 0.序 1.数组结构 1.1ngxarrayt结构 1.2ngxarrayt的逻辑结构 ...

晨曦之光
2012/03/09
153
0
Nginx源码分析链接

nginx-0.8.38源码探秘:http://blog.csdn.net/ccdd14/article/details/5872312 nginx源码分析: http://blog.sina.com.cn/s/blog677be95b0100iiv7.html 原文链接:http://blog.csdn.net/21as......

晨曦之光
2012/03/09
75
0
nginx源码分析—队列结构ngx_queue_t

本博客(http://blog.csdn.net/livelylittlefish )贴出作者(阿波)相关研究、学习内容所做的笔记,欢迎广大朋友指正! Content 0. 序 1. 队列结构 2. 队列操作 2.1 在头节点之后插入 2.2 ...

晨曦之光
2012/03/09
216
2
OSChina 第七期高手问答:Nginx源码解读和扩展开发

来自 Netcraft 2012年1月份的报告,Nginx 已经俨然成为第二大 Web 服务器软件。 本期 OSChina 高手问答,我们请来自广州的 @何海强 为我们答疑关于 Nginx 源码解读以及扩展模块开发方面的问题...

红薯
2012/02/12
6.5K
30
Nginx技术交流Q群:225942451(探讨安装、部署、模块开发、源码分析,及其他知名服务端开源软件)

Nginx交流Q群:225942451 讨论Nginx的安装、部署、模块开发、源码分析,及其他知名服务端开源软件。 - 原文链接:http://blog.csdn.net/poechant/article/details/7439179...

晨曦之光
2012/04/24
171
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

spring-@RequestBody

@RequestMapping("/login")    public void login(@RequestBody String userName,@RequestBody String pwd){      System.out.println(userName+" :"+pwd);    }    ......

说回答
4分钟前
0
0
Redis安装

大家可以通过该链接获取安装详情(这是一个Word文档,支持下载): http://note.youdao.com/noteshare?id=7a327ed6c58fb2037ba537e58ecf7510&sub=480DB8EF349747C3983B73AE94D45BB1 其他参考...

一梦心草
4分钟前
0
0
MySQL按天,按周,按月,按时间段统计【转载】

https://blog.csdn.net/qq_28056641/article/details/78306870 select DATE_FORMAT(create_time,'%Y%m%d') days,count(caseid) count from tc_case group by days; select DATE_FORMAT(creat......

李道福
6分钟前
0
0
浅谈parallelStream

parallelStream是什么,它是一个集合的并发处理流.其作用是把一个集合中的数据分片,进行一个多线程的处理,增快运行速度. 比如说这样一段代码 private Set<SysRole> sysRoles;private Set<St...

算法之名
8分钟前
2
0
器者,道之所载

形而上者谓之道,形而下者谓之器,化而裁之谓之变;推而行之谓之通,举而措之天下之民,谓之事业。—— 《道德经》

了凡川
9分钟前
0
0
C#命名规范中文版/C#编码规范中文版

最新文档地址https://github.com/hiramtan/CSharpNamingGuidelines_Chinese C#命名规范中文版/C#编码规范中文版 示例 /*****************************************************************......

海贝Hibey
11分钟前
0
0
刚从eclipse转到Intellij IDEA,分享一些配置经验

刚从eclipse转到Intellij IDEA,分享一些配置经验,IntelliJ IDEA作为最好的Java开发工具,在智能代码助手、代码自动提示、重构、J2EE支持、Ant、JUnit、CVS整合、代码审查、 创新的GUI设计等...

舒文joven
12分钟前
1
0
lombok 引入后,测试类始终找不到get,set方法。

开发环境为idea,jdk1.7,maven3.5. 网上直接搜出来的方法有: 1、在setting里安装lombok的plugins; 2、如下图,勾选enable annocation processing选项 3、升级maven plugins插件 我尝试了以...

Kidult
18分钟前
0
0
Duang,HUAWEI DevEco IDE全面升级啦

想感受全新UI带来的视觉及交互体验、 HiKey970开发板调测、 HiAI API推荐和收藏、 深度AI模型分析等新功能, 体验高清晰度和流畅度的远程AI真机调测吗? 全新的UI设计 采用最优秀的视觉及交互...

华为终端开放实验室
27分钟前
1
0
阻止事件冒泡,阻止默认事件

1.event.stopPropagation()方法 这是阻止事件的冒泡方法,不让事件向documen上蔓延,但是默认事件任然会执行,当你掉用这个方法的时候,如果点击一个连接,这个连接仍然会被打开, 2.event....

闫亚亚
29分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部