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