热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

nginxhttp处理过程分析之综述

综述为了节省大家时间和提高效率,这里给出两篇非常不错的文章,出自同一人(应该是雕梁)之手:1.nginx接受连接,请求处理

综述

为了节省大家时间和提高效率,这里给出两篇非常不错的文章,出自同一人(应该是雕梁)之手:

1.nginx接受连接,请求处理的前置工作处理

http://www.pagefault.info/?p=205

2.正式进行request请求处理

http://simohayha.iteye.com/blog/632115

这两篇文章基本上将nginx从连接建立到请求解析过程的绝大部分内容都讲清楚了,这里我想针对里面有些细节,或者是作者没有提到的一些重点地方,跟大家一起分享下。

这里以文章1中的一个流程图开始:

1.ngx_accept

(1)在ngx_event_process_init,即事件初始化阶段,会设置读事件(这里肯定是针对accpet了)的处理函数为ngx_event_accept,也就是说,当客户端连接到来时,触发的read事件,nginx就可以accpet这个连接了。

(2)这里我们忽略非epoll的条件判断,我们看到ev->available = ecf->multi_accept;

multi_accept是一个事件模块的一个配置指令,它的作用是控制accept的次数,即在每次新连接到来时,是获取一个连接还是accpet多个(并发连接较多时),考虑到多个worker进程的负载问题,如果multi_accept配置过大,可能使短时间一个进程过于忙绿,所以默认下,是不开启的,即一次只accpet一个连接。

(3)accept4系统调用

在nginx 0.9.0版本里面新增了accpet4的系统调用,这个系统调用比较新,好像是出现在2.6.28内核中,有趣的是正是上述文章的作者提交了这一patch,并最终得到了Igor的认可,呵呵。

这里简单说一下,这个系统调用的作用。一般我们在accept后,会对新的client fd做一些设置,如通过fcnt设置FD_CLOEXEC或者O_NONBLOCK等等,在accept4中的最后一个参数就是用来设置这两个参数:

intaccept4(int sockfd, struct sockaddr *addr, socklen_t *addrlen, int flags);

flags:SOCK_NONBLOCKor SOCK_CLOEXEC

为什么只有这两个flag吗?不清楚,我个人认为是这两个选项比较常用,这样一来的目的就可以让开发者少敲代码,降低出错的可能吧==!

2.ngx_http_init_connection

ngx_event_accept中通过ls->handler(c),来调用了ngx_http_init_connection。这里的工作中,有个设置write->handler的操作:

// ngx_http_empty_handler基本上是个空操作,除了打印一些信息之外,其他什么也没做。// 这样设计的意图在于,在处理请求的read事件阶段,没有需要write的动作,// 如果确实得到了write事件,那么就忽略它了。c->write->handler= ngx_http_empty_handler;


3.ngx_http_init_request

在这个函数中涉及到一个问题,就是如何根据一个接收到的连接,来确定要使用哪个server conf的配置。这里给出一个对这个问题阐述比较好的文章:

http://bollaxu.iteye.com/blog/859168

在之后设置请求内容的处理函数:

rev->handler= ngx_http_process_request_line;

r->read_event_handler= ngx_http_block_reading;

上面有个read_event_handler的设置,ngx_http_block_reading函数主要是移除read事件。这样做的目的是,是为了在处理当前的request时间内,暂时停止处理新的请求,因为同一连接内会有有多个所谓的pipeline请求。而什么时间来继续处理新请求,由程序来控制,需要的时候再处理(如在keepalive相关处理)。

后面的内容,如request的解析,run_phases 中handler的处理等等,在前面介绍的作者的blog中都有很详细的分析,大家可以参考下:

http://simohayha.iteye.com/category/101180




推荐阅读
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • Imtryingtofigureoutawaytogeneratetorrentfilesfromabucket,usingtheAWSSDKforGo.我正 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • “你永远都不知道明天和‘公司的意外’哪个先来。”疫情期间,这是我们最战战兢兢的心情。但是显然,有些人体会不了。这份行业数据,让笔者“柠檬” ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
    本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
  • Google在I/O开发者大会详细介绍Android N系统的更新和安全性提升
    Google在2016年的I/O开发者大会上详细介绍了Android N系统的更新和安全性提升。Android N系统在安全方面支持无缝升级更新和修补漏洞,引入了基于文件的数据加密系统和移动版本的Chrome浏览器可以识别恶意网站等新的安全机制。在性能方面,Android N内置了先进的图形处理系统Vulkan,加入了JIT编译器以提高安装效率和减少应用程序的占用空间。此外,Android N还具有自动关闭长时间未使用的后台应用程序来释放系统资源的机制。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
author-avatar
手浪用户2602936705
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有