fastcgi介绍

    xiaoxiao2021-12-13  19

    fastcig协议

    FastCGI 将传输的消息做了很多类型的划分,其结构体定义如下: typedef enum _fcgi_request_type {     FCGI_BEGIN_REQUEST      =  1, /* [in]                              */     FCGI_ABORT_REQUEST      =  2, /* [in]  (not supported)             */     FCGI_END_REQUEST        =  3, /* [out]                             */     FCGI_PARAMS             =  4, /* [in]  environment variables       */     FCGI_STDIN              =  5, /* [in]  post data                   */     FCGI_STDOUT             =  6, /* [out] response                    */     FCGI_STDERR             =  7, /* [out] errors                      */     FCGI_DATA               =  8, /* [in]  filter data (not supported) */     FCGI_GET_VALUES         =  9, /* [in]                              */     FCGI_GET_VALUES_RESULT  = 10  /* [out]                             */ } fcgi_request_type; 常见消息流程 FCGI_BEGIN_REQUEST  FCGI_PARAM  FCGI_STDIN  FCGI_STDOUT FCGI_STDERR FCGI_END_REQUEST  由于整个消息是二进制连续传递的,所以必须定义一个统一的结构的消息头,这样以便读取每个消息的消息体,方便消息的切割。这在网络通讯中是非常常见的一种手段。 typedef struct _fcgi_header {     unsigned char version;     unsigned char type;     unsigned char requestIdB1;     unsigned char requestIdB0;     unsigned char contentLengthB1;     unsigned char contentLengthB0;     unsigned char paddingLength;     unsigned char reserved; } fcgi_header; version标识FastCGI协议版本。 type 标识FastCGI记录类型,也就是记录执行的一般职能。 requestId标识记录所属的FastCGI请求。 contentLength记录的contentData组件的字节数。 协议头中requestId和contentLength表示的最大值就是 65535。 typedef struct _fcgi_begin_request {     unsigned char roleB1;     unsigned char roleB0;     unsigned char flags;     unsigned char reserved[5]; } fcgi_begin_request; 字段解释: role表示Web服务器期望应用扮演的角色。分为三个角色(而我们这里讨论的情况一般都是响应器角色) 而FCGI_BEGIN_REQUEST中的flags组件包含一个控制线路关闭的位:flags & FCGI_KEEP_CONN:如果为0,则应用在对本次请求响应后关闭线路。如果非0,应用在对本次请求响应后不会关闭线路;Web服务器为线路保持响应性。 typedef struct _fcgi_end_request {     unsigned char appStatusB3;     unsigned char appStatusB2;     unsigned char appStatusB1;     unsigned char appStatusB0;     unsigned char protocolStatus;     unsigned char reserved[3]; } fcgi_end_request; appStatus组件是应用级别的状态码。 protocolStatus组件是协议级别的状态码;protocolStatus的值可能是: FCGI_REQUEST_COMPLETE:请求的正常结束。 FCGI_CANT_MPX_CONN:拒绝新请求。这发生在Web服务器通过一条线路向应用发送并发的请求时,后者被设计为每条线路每次处理一个请求。 FCGI_OVERLOADED:拒绝新请求。这发生在应用用完某些资源时,例如数据库连接。 FCGI_UNKNOWN_ROLE:拒绝新请求。这发生在Web服务器指定了一个应用不能识别的角色时。 lex/yacc (flex/bison) re2c/bison
    转载请注明原文地址: https://ju.6miu.com/read-950095.html

    最新回复(0)