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使用的资源

传统方法中常用的钩子:

uscf->peer.init_upstream. 初始化 upstream配置,

在upstream配置初始化过程中用钩子us->peer.init初始化请求,

在初始化请求中往往创建请求和upstream的关系,然后用钩子peer.get定义获取后端服务器方法等,peer.free与peer.get匹配。

最新文章

  1. SQL Server2016升级前几点自检
  2. CentOS6.3 编译安装LAMP(4):编译安装 PHP5.2.17
  3. storm学习
  4. Android性能测试工具APT使用指南
  5. 意译:《JVM Internals》
  6. 【BZOJ-3697&3127】采药人的路径&YinandYang 点分治 + 乱搞
  7. VirtualBox centos 6.5 minimal 开启网络
  8. 并发用户数与 TPS 之间的关系
  9. web可用性测试
  10. POSTMAN中各种请求方式的区别
  11. 11235 - Frequent values
  12. OM Price Lists
  13. Python多进程使用
  14. 技术七Gitservergitolite要构建和操作方便
  15. C++ 进制转换 十进制十六进制八进制二进制相互转换
  16. UOJ#110. 【APIO2015】Bali Sculptures 贪心 动态规划
  17. Elasticsearch Elasticsearch入门指导
  18. Java的小实验——各种测试以及说明
  19. sql语句修改字段约束为不为空 并为其设置主键
  20. python操作Mysql数据库示例

热门文章

  1. Linux系统字符集乱码问题
  2. Codeforces Round #275 (Div. 2) C
  3. web.xml中url-pattern匹配规则
  4. oracle中sql执行性能关注点
  5. oracle分区表和分区索引概述
  6. hive beeline 的server启动与连接
  7. JQ多种刷新方式
  8. 传统数据仓库架构与Hadoop的区别
  9. Mysql 复制表数据(表结构相同)
  10. 同步与异步区别,Invoke与BeginInoke的区别