nginx源码中upstream的主要流程

Posted bewolf

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nginx源码中upstream的主要流程相关的知识,希望对你有一定的参考价值。

upstream 即上游的意思,是一个想对到概念,从客户端到中间的网络链路到服务器到链路中,可以将越接近客户到设备越理解成下游,相反到为上游,所以如果只有一个upstream,可以将其为理解成转发客户到请求到服务器,然后响应服务器转发到客户端到过程,源码主要流程如下:

 

1、创建upstream           

ngx_http_upstream_init

  删除超时定时器

  创建到上游到请求

  挂接一些处理函数,包含第6步中要用到的请求结束后upstream到清理函数

2、建立与上游的连接

ngx_http_upstream_connect

    创建socket、connetion,发起tcp建连请求,使用epoll发送请求,挂接upstream的handler,包括第4、5步中处理上游应答的处理函数

 

3、发送到上游的请求 

ngx_http_upstream_send_request

4、处理上游的响应头

process_header 解析请求头

ngx_http_upstream_process_headers处理请求头

 

5、处理上游的响应体

ngx_http_upstream_process_body_in_memory

如果需要转发相应体,可以自己实现input_filter,若不自己实现则使用默认的ngx_http_upstream_non_buffered_filter

 (1)upstream与上游之间网速很快时,使用大内存甚至文件,缓存上游大请求

 (2)upstream与下游之间网速很快时,使用固定大小内存,不需要过多缓存请求

ngx_http_upstream_send_response中通过判断

buffering决定走上述的那个流程

 

6、结束upstream 请求

ngx_http_upstream_cleanup

主要释放一些upstream使用的资源

以上是关于nginx源码中upstream的主要流程的主要内容,如果未能解决你的问题,请参考以下文章

nginx + lua 有没有办法获取到 upstream 中某个上游挂了的信息

如何在upstream中使用nginx变量

nginx源码层面探究request_timeupstream_response_timeupstream_connect_time与upstream_header_time指标具体含义

09 nginx 中 upstream max_conns 配置为 1, 导致的一部分静态资源请求成功, 一部分静态资源请求失败

09 nginx 中 upstream max_conns 配置为 1, 导致的一部分静态资源请求成功, 一部分静态资源请求失败

09 nginx 中 upstream max_conns 配置为 1, 导致的一部分静态资源请求成功, 一部分静态资源请求失败