zoukankan      html  css  js  c++  java
  • nginx源码中upstream的主要流程

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

     

    配置解析:

    ngx_http_upstream_commands

    ngx_http_upstream_init_round_robin  中peer构造

     

    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匹配。

  • 相关阅读:
    安装node.js webkit环境[一]
    wpf 窗口最小化后,触发某事件弹出最小化窗口并置顶
    c# 旋转图片 无GDI+一般性错误
    类库里面添加日志记录 log4net
    string转xml
    DES c#加密后java解密
    使用排序字典排序
    怎么让一段xml被识别为字符串
    新装iis 页面503错误 DefaultAppPool停止解决方案
    hession
  • 原文地址:https://www.cnblogs.com/bewolf/p/10960450.html
Copyright © 2011-2022 走看看