实现方式
mirror逻辑的工作阶段:
ngx在log phase之后(在ngx_http_free_request处调用)已完成向client端返回response,在log phase之后完成close connection(短链接),在该阶段处理mirror逻辑不会对主请求造成阻塞。
发往mirror upstream的流量获取:
request结构中有向后端upstream转发的数据缓存,并且request和内存资源独立于底层connection的内存资源,因此可复用request结构及内存(待mirror之后释放)作为向mirror upstream转发的数据来源,复用该数据可最大程度减少重新组包或数据copy带来的性能损耗。
r->upstream→request_bufs:原向后端转发,组成的http头
r→request_body:收到的http body
注意:复用该方法会有一个问题在于如果主请求不能转发到后端,则不会生成该http 头数据。例如 404 not found的请求,因为找不到指定路径,所以不会走proxy逻辑生成到upstream的请求数据。
逻辑顺序