F5地址:172.10.10.10:8081
WAS地址:
A:192.168.1.13:9080
B:192.168.1.14:9080
描述:F5地址的8081端口本来是负载均衡A和B两台主机的80端口的,但因WAS非root用户安装,无法使用1024以下端口,所以使用应用的默认端口9080;外部在访问F5地址的8081端口时,F5把请求根据配置转发到A和B中的一台处理;
异常现象:当WAS中的应用使用重定向时,比如,用户没有登录重定向到登录页面,期望的URL是:http://172.10.10.10:8081/login.jsp,实际的URL是:http://172.10.10.10:9080/login.jsp,并且访问没有重定向的页面时经常出现404找不到资源的现象。
通过分析F5、A和B的日志,发现在重定向时WAS把默认应用端口带着返回了,F5地址根据带着WAS端口的重定向的URL请求时。
参照WAS官方文档:https://www.ibm.com/support/knowledgecenter/zh/SSAW57_8.5.5/com.ibm.websphere.nd.doc/ae/rweb_custom_props.html?cp=SSAW57_8.5.5
com.ibm.ws.webcontainer.extractHostHeaderPort 和 trusthostheaderport
- 从请求 URL 返回端口号
- 从请求主机头返回端口号
trusthostheaderport = true
com.ibm.ws.webcontainer.extractHostHeaderPort = true
根据上述说明:设置了
trusthostheaderport = true
com.ibm.ws.webcontainer.extractHostHeaderPort = true
后,异常照旧,并且经常出现:
SRVE0255E: 尚未定义要处理 XXXX 的 Web 组/虚拟主机。
解决办法:
1:把A和B的WAS中应用的端口改为8081
2:把F5中映射的WAS端口也改为8081
把A和B的端口改为和F5地址的端口一致后,问题解决!com.ibm.ws.webcontainer.extractHostHeaderPort=true
trusthostheaderport=true,也没设置。