《深入理解Nginx》笔记之 ngx_mail相关结构体
2015-08-26 13:28
471 查看
Nginx mail相关模块结构体
ngx_mail_module_t
这是mail模块的抽象接口,即ngx_module_t中的ctx成员所指向的mail模块特有接口。每一个mail模块都会实现自己的ngx_mail_module_t结构体。typedef struct { // POP3 STMP IMAP邮件模块提取出的通用接口 ngx_mail_protocol_t *protocol; // 用于创建main级别配置项的结构体 void *(*create_main_conf)(ngx_conf_t *cf); // 解析完main级别配置项后被回调的函数 char *(*init_main_conf)(ngx_conf_t *cf, void *conf); // 用于创建srv级别配置项的结构体 void *(*create_srv_conf)(ngx_conf_t *cf); // 根据具体模块处理srv下和main下同名的配置项 char *(*merge_srv_conf)(ngx_conf_t *cf, void *prev, void *conf); } ngx_mail_module_t;
ngx_protocol_s
typedef struct ngx_mail_protocol_s ngx_mail_protocol_t; // 四个POP3 SMTP IMAP等应用级别的邮件模块所需要实现的接口方法 typedef void (*ngx_mail_init_session_pt)(ngx_mail_session_t *s, ngx_connection_t *c); typedef void (*ngx_mail_init_protocol_pt)(ngx_event_t *rev); typedef void (*ngx_mail_auth_state_pt)(ngx_event_t *rev); typedef ngx_int_t (*ngx_mail_parse_command_pt)(ngx_mail_session_t *s); struct ngx_mail_protocol_s { // 邮件模块名称 ngx_str_t name; // 当前邮件模块中所要监听的最常用4个端口 in_port_t port[4]; // 邮件模块类型 ngx_uint_t type; // 与客户端建立起TCP连接后的初始化方法 ngx_mail_init_session_pt init_session; // 接收、解析客户端请求的方法 ngx_mail_init_protocol_pt init_protocol; // 解析客户端邮件协议的接口方法 ngx_mail_parse_command_pt parse_command; ngx_mail_auth_state_pt auth_state; // 当处理中没有遇到错误时,返回internal_server_error指定的响应给客户端 ngx_str_t internal_server_error; ngx_str_t cert_error; ngx_str_t no_cert; };
ngx_mail_session_t
Nginx与客户端建立TCP连接后,将会回调ngx_mail_init_connection函数初始化邮件协议。这个时候,会创建一个类似于HTTP请求中的ngx_http_request_t这样的核心结构体:ngx_mail_session_s。typedef struct { uint32_t signature; /* "MAIL" */ // 下游客户端和Nginx之间的连接 ngx_connection_t *connection; // 可存需要向下游客户端发送的内容 ngx_str_t out; // 用于接收来自客户端的请求 ngx_buf_t *buffer; // 指向一个指针数组,保存着这个请求中各个邮件模块的上下文建构体指针 void **ctx; // main级别配置结构体组成的指针数组 void **main_conf; // srv级别配置结构体组成的指针数组 void **srv_conf; // 解析主机域名 ngx_resolver_ctx_t *resolver_ctx; // proxy上下文,用于Nginx双向透传客户端与邮件服务器间的通信 ngx_mail_proxy_ctx_t *proxy; // 表示与邮件服务器交互时,当前处于哪种状态 ngx_uint_t mail_state; // 邮件协议类型 unsigned protocol:3; // 1:表示当前读或写操作需要被阻塞 unsigned blocked:1; // 1:请求需要结束 unsigned quit:1; // 一下三个标志位仅在解析具体邮件协议时由邮件框架使用 unsigned quoted:1; unsigned backslash:1; unsigned no_sync_literal:1; // 当使用SSL协议时才有意义 unsigned starttls:1; unsigned esmtp:1; // 表示与认证服务器交互时的记录认证方式 unsigned auth_method:3; // 1:表示认证服务器要求暂缓接收响应,Nginx会继续等待认证服务器的后续响应 unsigned auth_wait:1; // 验证时的用户名 ngx_str_t login; // 验证时的密码 ngx_str_t passwd; // 作为Auth-Salt验证的信息 ngx_str_t salt; // 一下三个成员仅用于IMAP通信 ngx_str_t tag; ngx_str_t tagged_line; ngx_str_t text; // 当前连接上对应的Nginx服务器地址 ngx_str_t *addr_text; // 主机地址 ngx_str_t host; //一下四个成员仅用于SMTP通信 ngx_str_t smtp_helo; ngx_str_t smtp_from; ngx_str_t smtp_to; ngx_str_t cmd; // 在于邮件服务器交互时,表示解析自邮件服务器的消息类型 ngx_uint_t command; // 存放来自下游客户端的邮件协议中的参数 ngx_array_t args; // 当前请求尝试访问服务器验证的次数 ngx_uint_t login_attempt; /* used to parse POP3/IMAP/SMTP command */ ngx_uint_t state; u_char *cmd_start; u_char *arg_start; u_char *arg_end; ngx_uint_t literal_len; } ngx_mail_session_t;
ngx_mail_proxy_ctx_t
typedef struct { // 与上游邮件服务器间的连接 ngx_peer_connection_t upstream; // 用于缓存上、下游间TCP消息的内存缓冲区 ngx_buf_t *buffer; } ngx_mail_proxy_ctx_t;
ngx_mail_auth_http_ctx_t
用于Nginx与邮件认证服务器的认证过程。typedef struct ngx_mail_auth_http_ctx_s ngx_mail_auth_http_ctx_t; // 解析认证服务器HTTP响应的函数指针 typedef void (*ngx_mail_auth_http_handler_pt)(ngx_mail_session_t *s, ngx_mail_auth_http_ctx_t *ctx); struct ngx_mail_auth_http_ctx_s { // request缓冲区保存着发往认证服务器的请求 ngx_buf_t *request; // 保存认证服务器返回的响应缓冲区 ngx_buf_t *response; // Nginx与认证服务器间的连接 ngx_peer_connection_t peer; // 解析来自认证服务器的响应行、头部的函数 ngx_mail_auth_http_handler_pt handler; // 状态机解析认证服务器返回响应时的状态 ngx_uint_t state; // 用于解析返回的响应头部用 u_char *header_name_start; u_char *header_name_end; u_char *header_start; u_char *header_end; // 认证服务器返回的Auth-Server头部 ngx_str_t addr; // 认证服务器返回的Auth-Port头部 ngx_str_t port; ngx_str_t err; ngx_str_t errmsg; ngx_str_t errcode; // 认证服务器返回的Auth-Wait头部时带的时间戳将会被设置到sleep成员中 time_t sleep; ngx_pool_t *pool; };
相关文章推荐
- Nginx+UWSGI+Django配置全过程
- Mac10.9.3仅安装Nginx
- nginx
- eclipse 插件及其配置(jdk+eclipse+svn+maven+jetty+nginx)
- 解决 nginx: [alert] kill(189, 1) failed (3: No such process)
- 解析nginx负载均衡
- nginx的upstream目前支持4种方式的分配
- nginx实现负载均衡相关配置
- CentOs下Nginx安装部署
- python+django+fastcgi+nginx
- nginx实现web负载均衡
- 统计Apache或nginx日志里访问次数最多的前十个IP
- linux下nginx多版本php共存
- nginx日志分割处理以及分析
- nginx+keepalived双主高可用负载均衡
- keepalived+nginx实现双机热备
- Nginx 配置 Basic 认证
- nginx、fastCGI、php-fpm关系梳理
- CentOS添加nginx yum源
- Nginx 虚拟主机配置及负载均衡