proxy: Max-Forwards has reached zero - proxy loop?

某个页面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

The ProxyMaxForwards directive specifies the maximum number of proxies through which a request may pass, if there's no Max-Forwards header supplied with the request. This is set to prevent infinite proxy loops, or a DoS attack.
 



该指令描述的是:一个请求,最多能通过多少次proxy来转发。一个客户端请求,多次proxy转发,场景一般有如下几种:

1、请求/backend,proxyA转发给proxyB,proxyB又转发给proxyA。形成无限循环。
2、请求/backend,proxyA转发给proxyB,proxyB转发给proxyC,...,proxyY转发给proxyZ。形成较长的转发链。
3、一个SSI页面请求,webserver解析完include指令,多次请求了同一个proxy(类似DoS attach的效果),合并输出。


你可能感兴趣的:(apache,dos,Google)