Nginx HTTP框架综述

本文介绍了Nginx HTTP框架的基本组成与处理流程,详细解释了核心模块的作用及请求处理的各个阶段,帮助读者理解Nginx的工作原理。

1. 框架简介

Nginx的HTTP框架是由core模块ngx_http_module 和 http模块ngx_http_core_module共同定义的。ngx_http_module定义了指令 http,保存和管理各个层次里所有http模块的配置数据(我们已经在第6章了解了它的上作原理);而ngx_http_core_module则是http模块的“核心”模块,它定义了listen、server、location等 http核心指令,搭建了Nginx的HTTP处理框架。

1.1 模块分类

http模块处理现今应用得最广泛的HTTP协议,也是目前Nginx里数量最多的模块,按照功能分类可以分为四种:

handler   直接处理客户端的请求,产生响应数据,是最常用的模块;
filter     对handler模块产生的数据做各种加工过滤处理;
upstream   实现反向代理功能,转发请求到上游服务器,从后端获取响应数据再发回给客户端;
load-balance 不直接处理数据,而是实现负载均衡算法,从upstream块的配置里选择一个合适的上游服务器。

1.2 处理流程
1.2.1 通用的处理流程

本节简要介绍Nginx的HTTP工作流程,这是理解Nginx HTTP框架的基础。
通用的处理流程:          
web 服务器的HTTP请求处理流程可以粗略地叙述为如下的顺序步骤:
(1)监听端口,接受客户端的连接;
(2)读取请求头,包括请求行(request line)和请求头(headers);
(3)读取或者丢弃请求体(body);
(4)生成并发送响应头;
(5)生成并发送响应体.

上面只是最简单的HTTP处理流程,Nginx使用了操作系统提供的事件驱动模型(epoll、kqueue等)来实
现异步并发,并且还增加了很多其他功能, 如权限检查、重定向、缓存、记录访问日志等,使HTTP处理
流程变得十分复杂.

1.2.2 Nginx的处理流程

如果我们忽略Nginx的异步机制,把注意力集中在处理逻辑上,那么可以看到Nginx
的主处理流程与基本的HTTP处理流程区别并不大,它的工作流程如下:
(1)监听端口,设置回调为ngx_http_init_connection();
(2)接受客户端的连接,调用ngx_http_wait_request_handler();
(3)调用ngx_http_create_request()创建请求对象;
(4)接收数据,调用ngx_http_process_request_line()解析请求行;
(5)请求行接收完毕,继续接收数据,调用ngx_http_process_request_headers()解析请求头;
(6)请求头接收完毕,调用ngx_http_process_request()设置异步读写事件. 
   注意:为了提高运行效率,Nginx不会主动处理请求体.
(7)调用ngx_http_handler()开始真正处理请求;
(8)调用ngx_http_core_run_phases()按阶段处理请求. 这是HTTP框架的核心部分,大部分http模块都在
   这里运行,最终产生响应数据. 
(9)调用ngx_http_send_header()发送响应头,从函数指针ngx_http_top_header_filter开始,
   通过header filter模块链过滤处理,最终发送处理过的响应头.
(10)调用ngx_http_output_filter()发送响应体,从函数指针ngx_http_top_body_filter开始,
   通过body filter模块链过滤处理,最终发送处理过的响应体.
(11)处理完毕,记录访问日志.

ngx_http_init_connection 

ngx_module_t  ngx_http_module = {
    NGX_MODULE_V1,
    &ngx_http_module_ctx,                  /* module context */
    ngx_http_commands,                     /* module directives */
    NGX_CORE_MODULE,                       /* module type */
    NULL,                                  /* init master */
    NULL,                                  /* init module */
    NULL,                                  /* init process */
    NULL,                                  /* init thread */
    NULL,                                  /* exit thread */
    NULL,                                  /* exit process */
    NULL,                                  /* exit master */
    NGX_MODULE_V1_PADDING
};


static ngx_command_t  ngx_http_commands[] = {

    { ngx_string("http"),
      NGX_MAIN_CONF|NGX_CONF_BLOCK|NGX_CONF_NOARGS,
      ngx_http_block,
      0,
      0,
      NULL },

      ngx_null_command
};

static char *ngx_http_block(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
{
    // ...
    if (ngx_http_optimize_servers(cf, cmcf, cmcf->ports) != NGX_OK) 
	{
        return NGX_CONF_ERROR;
    }
	// ...
}


static ngx_int_t 
ngx_http_optimize_servers(ngx_conf_t *cf, ngx_http_core_main_conf_t *cmcf,ngx_array_t *ports)
{
    // ...
	ngx_http_init_listening
	// ...
}


ngx_http_init_listening(ngx_conf_t *cf, ngx_http_conf_port_t *port)
{
  //...
  ls = ngx_http_add_listening(cf, &addr[i]);
  //...
}

ngx_http_add_listening()
{
  // ...
  ls->handler = ngx_http_init_connection;
  // ...
}

简介: 本框架是在Netroid的基础之上进行了封装,节省了其中配置的过程和一些不必要的操作 主要进行文本请求和图片请求,图片请求都进行了缓存(内存缓存和sd卡缓存)的封装,sd卡缓存时间可自行更改. 文本请求可传入解析的泛型clazz,即可返回解析后的clazz对象进行数据 操作,如果不需要进行数据解析,可通过另一种方式获取原生的string; 单图请求,单图请求可执行对本地asset文件夹,sd卡,http三种请求模式.只需传入相应的路径即可; 多图请求,多图请求主要是针对listview这种图文混排模式而生,能快速加载图片并实现缓存,不需要考虑 图片错位问题.只需传入相应的url即可完成全部功能. 使用说明: 1:在新创建的Manifest.xml中application中申明: <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" android:name="com.aqs.application.UApplication" > 并初始化Const.init();此处的初始化主要是对内存缓存,SD卡缓存大小,缓存时间等进行设置,如果不初始化,则按使用默认配置; 2:依赖HttpAqs-library或者jar包 3:通过公有方法进行网络请求,示例如下: >文本请求: >解析后的文本请求: HttpRequest.reqquest(int,String,Parse,Class){....}; >原生string文本请求: HttpRequest.getString(String,AqsString){...} >单张图片请求: HttpRequest.setImage(ImageView,String,int,int){...} >多张图片请求: 可使用AQSImageView控件来加载图片;特别是针对listview图文混排 实现方法: >在布局中添加 >在代码中 av.setImageUrl(url);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值