使用多个tomcat实现负载均衡后,tomcat端口不对外开放的情况下,实现精确访问tomcat的方法
- 背景:
使用Nginx和两个Tomcat实现了负载均衡,并在防火墙中关闭了tomcat的端口(8080和8090),对外只开放80端口。Nginx配置如下:
upstream tomcatCluster {
server
server
}
server
{
listen 80;
server_name dev.xjj.cn
……
location / {
……
location ~* /
include proxy.conf;
proxy_pass http://tomcatCluster;
}
}
……
}
注:两个tomcat的端口分别为8080和8090,location语句根据请求URI中的关键字“/
- 需求:
当其中一个tomcat升级后,需要直接访问它的页面以测试是否有错误。
- 需求分析:
Tomcat端口已经被防火墙禁止外部访问,无法直接通过“http://
- 解决方案:
可以通过Nginx的rewrite结合proxy_pass实现对某个tomcat的直接访问,配置及解释如下,在Nginx的location配置中添加两个location配置:
#8080端口测试页面专用
location ~* /tomcat8080-
include proxy.conf;
rewrite ^/tomcat8080-(.*) /$1 break;
proxy_pass http://192.168.0.9:8080;
}
#8090端口测试页面专用
location ~* /tomcat8090-
include proxy.conf;
rewrite ^/tomcat8090-(.*) /$1 break;
proxy_pass http://192.168.0.9:8090;
}
注(以第二个为例):
rewrite语句:把请求URI http://dev.xjj.cn/tomcat8090-
proxy_pass语句:把请求http://dev.xjj.cn/
这样,通过rewrite和proxy_pass语句的结合,实现了对某个tomcat的精确访问。
以上就介绍了使用多个tomcat实现负载均衡后,tomcat端口不对外开放的情况下,实现精确访问tomcat的方法,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。