nginx-push-stream模块源码学习(三)——发布
一、概述
发布:发布者将MSG post到某一特定通道上,channel将信息缓存
在说明发布流程之前有必要说明下channel和msg的数据结构。
二、数据结构
2.1 MSG
发布时,模块先将消息转化为ngx_http_push_stream_msg_t的数据结构进行存储。

// now let's respond to some requests! //对于该channel上的所有订阅者 while ((cur = (ngx_http_push_stream_queue_elem_t *) ngx_queue_next(&cur->queue)) != subscribers_sentinel) { ngx_http_push_stream_subscriber_t *subscriber = (ngx_http_push_stream_subscriber_t *) cur->value; //如果订阅者为longpolling模式 if (subscriber->longpolling) { ngx_http_push_stream_queue_elem_t *prev = (ngx_http_push_stream_queue_elem_t *) ngx_queue_prev(&cur->queue); //发送longpolling头(last Modified/Etag) ngx_http_push_stream_add_polling_headers(subscriber->request, msg->time, msg->tag, subscriber->request->pool); ngx_http_send_header(subscriber->request); //发送模块配置header模板 ngx_http_push_stream_send_response_content_header(subscriber->request, ngx_http_get_module_loc_conf(subscriber->request, ngx_http_push_stream_module)); //发送响应MSG ngx_http_push_stream_send_response_message(subscriber->request, channel, msg); //发送footer模板,last chunck("\0"CRLF CRLF) ngx_http_push_stream_send_response_finalize(subscriber->request); cur = prev; } else {//stream或polling模式 if (ngx_http_push_stream_send_response_message(subscriber->request, channel, msg) == NGX_ERROR) { ngx_http_push_stream_queue_elem_t *prev = (ngx_http_push_stream_queue_elem_t *) ngx_queue_prev(&cur->queue); ngx_http_push_stream_send_response_finalize(subscriber->request); cur = prev; } }