某个页面ssi的include指令经常报错,其源码是这样的:
<!--#include virtual="/backend/res?resId=r1" -->
<!--#include virtual="/backend/res?resId=r2" -->
...
<!--#include virtual="/backend/res?resId=rN" -->
页面包含了相当多的动态片段。由于该页面外部是不可访问的,故简单采用ssi处理。
N大约在11左右,include指令就出错了,[an error occurred while processing this directive]
初步猜想可能是include指令太多。打开apache的debug日志,出错时显示:proxy: Max-Forwards has reached zero - proxy loop? returned by /backend/res
google关键字"Max-Forwards has reached zero - proxy loop",这个问题的场景是:
前端proxy到自身,形成无限循环。该页面不属于这种情况。
google关键字“apache proxy forward max”,找到apache指令:ProxyMaxForwards
该指令描述的是:一个请求,最多能通过多少次proxy来转发。一个客户端请求,多次proxy转发,场景一般有如下几种:
1、请求/backend,proxyA转发给proxyB,proxyB又转发给proxyA。形成无限循环。
2、请求/backend,proxyA转发给proxyB,proxyB转发给proxyC,...,proxyY转发给proxyZ。形成较长的转发链。
3、一个SSI页面请求,webserver解析完include指令,多次请求了同一个proxy(类似DoS attach的效果),合并输出。