nginx+多tomcat实现单IP、多域名、多站点的访问

其实这个问题分为两个子问题来解决:

1.如何实现单IP多tomcat站点

2.对于多域名的多个站点如何通过nginx分发访问

问题一:解决方案又分为两种:

a.单实例tomcat配置多个host站点

这种方法有一个缺点就是无法分站点调试,如果一个站点出了问题,关服务进行调试会停掉所有站点(不过这个方案就不会涉及到第二个问题,因为这样单实例无法实现多个站点对应多个顶级域名)

b.多实例tomcat配置实现单机多站点

这个方法很简单,就相当于把tomcat拷贝多份,然后修改各个tomcat的server.xml中的shutdown,http以及AJP1.3的端口,然后将tomcat实例启动即可。不过这个对内存要求比较高,因为每个tomcat跑起来之后可能会占200M左右内存,这还是对并发量比较小的,如果实例数一多起来,比如我们现在有个项目需要20多个站点放在一台服务器上(主要是贪腐无处不在,钱有但是不给你买硬件。。无力吐槽。。。。),这样4G多的内存就吃掉了。

另外一点就是通过多实例配置多站点会有另外一个问题,可能每一个站点都有一个单独的顶级域名,而域名的解析止于IP,因此端口的映射需要自己另做,这就涉及到了第二个问题如何解决了。

具体如何配置多实例实现单机多站点,可以参照下面几个链接:

http://weihaoma.cn/archives/67

http://www.ff-bb.cn/logs/109466274.html

上面我说到可能会有内存溢出的问题,可以看看第二个链接中的解决方案,直接修改tomcat的内存参数,如果是linux直接修改catalina.sh即可,如果是windows的话需要修改注册表中Java的参数:HKEY_LOCAL_MACHINE\SOFTWARE\ApacheSoftwareFoundation\Procrun2.0\tomcat6.0\Parameters\Java

总体来讲问题一比较好解决,原理上很简单,单个实例无法调试就用多个实例,多个实例需要多个端口,当内存不足时修改它的启动参数,然后重启就行了。

问题二:这里我只说用nginx怎么解决,网上有人apache貌似也能解决,我没有弄成功

nginx是俄罗斯人写的一个开源的web服务器,国内的使用先驱是淘宝,而且貌似他们的工程师在写一本叫《nginx从入门到精通》的书。nginx是一个非常优秀的web服务器,可以说前途一片光明。

一般nginx现在多用户做负载均衡,配合tomcat或者apache做分发,网上这个讲的也很多,但是我要解决的问题不太相同,怎么样通过域名解析到不同端口,这得先说以下nginx的配置文件。

nginx配置文件位于conf/nginx.conf,它最主要的部分是http部分,这里最重要的两个配置项是upstream,server,这两个项都可以有多个配置。

#需要进行负载均衡的站点  
#其中server是其中负载均衡的一个节点www.aaa.com  
upstream www.aaa.com {    
        server 192.168.0.1:8080 weight=1;    
server 192.168.0.2:8080 weight=2;  
server 192.168.0.1:8081 weight=3;  
           
}    
  
#第二个网站的www.bbb.com的负载均衡的节点  
upstream www.bbb.com {    
        server 192.168.1.1:8080 ;    
server 192.168.1.2:8080 ;    
server 192.168.1.3:8080 ;    
        ip_hash;    
 }    
  
#同一服务器转发2个不同域名进行负载均衡  
#www.aaa.com的server  
server  
  {  
    listen       80;  
    server_name  www.aaa.com;  
     
        location / {    
            index  index.html index.jsp;    
            #这里的proxy_pass转发的是upstream的名字www.aaa.com  
            proxy_pass  http://www.aaa.com;    
            proxy_set_header    X-Real-IP   $remote_addr;    
            client_max_body_size    100m;    
        }    
          
    #limit_conn   crawler  20;      
      
}  
  
server  
  {  
    listen       80;  
    server_name  www.bbb.com;  
     
        location / {    
            index  index.html index.jsp;    
#这里的proxy_pass转发的是upstream的名字www.bbb.com  
            proxy_pass  http://www.bbb.com;    
            proxy_set_header    X-Real-IP   $remote_addr;    
            client_max_body_size    100m;    
        }    
          
    #limit_conn   crawler  20;      
      
}

tomcat配置:

//接下来更改三个端口号
<Server port="18005" shutdown="SHUTDOWN">


<Connector port="8801" protocol="HTTP/1.1"
       connectionTimeout="20000"
       redirectPort="8443" URIEncoding='UTF-8'/>


//tomcatX 在这里表示不同的tomcat,我的两个 tomcat 分别使用 tomcat1和tomcat2;  这个设置是主要用以tomcat的集群。
<Connector port="18009" protocol="AJP/1.3" redirectPort="8443" jvmRoute=" tomcatX"/>

DNS服务器将域名解析到IP地址,nginx作为反向代理收到请求之后根据配置文件将请求发送到对应的tomcat实例。

我测试时nginx反向代理放在我本机上,tomcat实例在同一台远程服务器,在hosts文件中虚拟两个域名假设为两实例中的站点的域名。

hosts文件路径C:\Windows\System32\drivers\etc

127.0.0.1       www.aaa.com
127.0.0.1       www.bbb.com

我已经测试过,这个方案是可行的,参考链接如下:

http://www.linuxde.net/2012/06/11006.html

相关推荐