Rumah  >  Artikel  >  pembangunan bahagian belakang  >  使用多个tomcat实现负载均衡后,tomcat端口不对外开放的情况下,实现精确访问tomcat的方法

使用多个tomcat实现负载均衡后,tomcat端口不对外开放的情况下,实现精确访问tomcat的方法

WBOY
WBOYasal
2016-08-08 09:28:321176semak imbas

  • 背景:

使用Nginx和两个Tomcat实现了负载均衡,并在防火墙中关闭了tomcat的端口(8080和8090),对外只开放80端口。Nginx配置如下:

upstream tomcatCluster {

        server :8080 ;

        server :8090 ;

}

server

{

        listen  80;

        server_name    dev.xjj.cn

        ……

        location / {

                ……

                location ~* //servlet/ {

                        include proxy.conf;

                        proxy_pass  http://tomcatCluster;

                }

        }

        ……

}

注:两个tomcat的端口分别为8080和8090,location语句根据请求URI中的关键字“//servlet/”把请求均衡分配到两个tomcat上。

  • 需求:

当其中一个tomcat升级后,需要直接访问它的页面以测试是否有错误。

  • 需求分析:

Tomcat端口已经被防火墙禁止外部访问,无法直接通过“http://:8080/”或“http://:8090/”访问某个tomcat进行测试。解决的方法只能通过Nginx转发。

  • 解决方案:

可以通过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-/*** 替换为http://dev.xjj.cn//***

proxy_pass语句:把请求http://dev.xjj.cn//*** 替换为 http://192.168.0.9:8090//***

这样,通过rewrite和proxy_pass语句的结合,实现了对某个tomcat的精确访问。


以上就介绍了使用多个tomcat实现负载均衡后,tomcat端口不对外开放的情况下,实现精确访问tomcat的方法,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn