设为首页 收藏本站
查看: 738|回复: 0

[经验分享] Tomcat负载均衡和集群配置

[复制链接]

尚未签到

发表于 2017-1-24 10:50:12 | 显示全部楼层 |阅读模式
  
1、准备
a) Tomcat 6.0.26 解压版。解压到D:\tomcat1和D:\tomcat2
b) Apache2.2.15安装版。安装到D:\apache2.
2、配置
1.1 httpd.conf配置
把下面的注释去掉。
# Virtual hosts
Include conf/extra/httpd-vhosts.conf
修改APACHE的配置文件D:\Apache2.2 \conf\httpd.conf
将以下Module的注释去掉,这里并没有使用mod_jk.so进行apache和tomcat的链接,从2.X以后apache自身已集成了mod_jk.so的功能。只需简单的把下面几行去掉注释,就相当于以前用mod_jk.so比较繁琐的配置了。这里主要采用了代理的方法。
     LoadModule proxy_module modules/mod_proxy.so
     LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
     LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
     LoadModule proxy_connect_module modules/mod_proxy_connect.so
     LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
     LoadModule proxy_http_module modules/mod_proxy_http.so
然后回到httpd.conf,在文档最下面加上
ProxyRequests Off 
<proxy balancer://cluster> 
       BalancerMember ajp://127.0.0.1:8009 loadfactor=1 route=jvm1
       BalancerMember ajp://127.0.0.1:9009 loadfactor=1 route=jvm2
</proxy>
ProxyRequests Off 是告诉Apache需要使用反向代理,ip地址和端口唯一确定了tomcat节点和配置的ajp接受端口。loadfactor是负载因子,Apache会按负载因子的比例向后端tomcat节点转发请求,负载因子越大,对应的tomcat服务器就会处理越多的请求,如两个tomcat都是1,Apache就按1:1的比例转发,如果是2和1就按2:1的比例转发。这样就可以使配置更灵活,例如可以给性能好的服务器增加处理工作的比例,如果采取多台服务器,只需要修改ip地址和端口就可以了。route参数对应后续tomcat配置中的引擎路径(jvmRoute)。

1.2、httpd-vhosts.conf设置
接下来进行虚拟主机的设置。APACHE的虚拟主机设置如下:
在文件(extra/httpd-vhosts.conf)最下面加入 
<VirtualHost *:80> 
         ServerAdmin webmaster@dummy-host2.hepx.com(这里是你安装apache填写的)
         ServerName localhost(这里是你安装apache填写的)
         ServerAlias localhost (这里是你安装apache填写的)
         ProxyPass /  balancer://cluster/ stickysession=jsessionid nofailover=On 
         ProxyPassReverse /  balancer://cluster/ 
         ErrorLog "logs/dummy-host2.hepx.com-error.log"
         CustomLog "logs/dummy-host2.hepx.com-access.log" common

 </VirtualHost>
ProxyPass为代理转发的Url,即将所有访问/的请求转发到群集balancer://cluster


2 配置 tomcat 
2.1. 配置 server 的关闭
我们需要在一台机器上跑 2 个不同的 tomcat ,需要修改不同的 tomcat 的关闭口,避免出现端口被占用的情况。
Tomcat_1\conf下的 server.xml中的<Server port="8005" shutdown="SHUTDOWN"> 不作修改保持默认,
Tomcat_2\conf下的server.xml中的<Server port="8005" shutdown="SHUTDOWN"> 修改为: 
<Server port="9005" shutdown="SHUTDOWN"> 

2.2. 配置 Engine
把tomcat_1和tomcat_2下原来的配置注释掉,如下:
<!-- <Engine name="Catalina" defaultHost="localhost"> --> 
把下面一句去掉注释。(jvmRoute的值对应apache/conf/httpd.conf中的BalancerMember的成员)
Tomcat_1: 
<Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm1">         
Tomcat_2:
<Engine name="Standalone" defaultHost="localhost" jvmRoute="jvm2"> 

2.3. 配置 Connector 
Connector 是apache和tomcat链接的关键,前台apache就是通过AJP协议与tomcat进行通信的,以完成负载均衡的作用。也可以用HTTP协议。
tomcat_1不作修改。保持默认。如下:
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
tomcat_2修改成:
<Connector port="9009" protocol="AJP/1.3" redirectPort="8443" />
其中的端口对应,tomcat_1 的ajp端口port:8009、tomcat_2 的ajp端口port:9009一定要与apache/conf/httpd.conf的BalancerMember配置的一致。同时也要把保持redirectPort的值唯一。

2.5.配置Cluster(每个tomcat中都要修改)
   向下找到<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>,去掉注释,这里的配置是为了可以在集群中的所有tomcat节点间共享会话(Session)。如果仅仅为了获得一个可用的tomcat集群,Cluster只需要这么配置就可以了。
3、测试负载均衡和集群
我在tomcat1和tomcat2下的webapps下加入test工程。新建一个index.jsp作为测试页面。在test目录下继续新建WEB-INF目录和web.xml,在<web-app>节点下加入<distributable />,这一步非常重要,是为了通知tomcat服务器,当前应用需要在集群中的所有节点间实现Session共享。如果tomcat中的所有应用都需要Session共享,也可以把conf/context.xml中的
<Context>改为<Context distributable="true">,这样就不需对所有应用的web.xml再进行单独配置。
1、启动服务,测试tomcat(启动顺序:apache、tomcat1、tomcat2)
在浏览器中输入:http://localhost/test/index.jsp如下:
DSC0000.jpg
同时看到后台的tomcat1打印了信息:如下:
DSC0001.jpg
我们再刷新一下页面.此时tomcat2打印信息了:如下:
DSC0002.jpg
我们在页面当中输入内容然后查看后台打印的信息。我们输入如下内容:
DSC0003.jpg
点击提交看后台打印的信息:(tomcat1打印)
DSC0004.jpg
我们再回到页面输入tomcat2 ,9090 提交后如下:(tomcat2打印)
DSC0005.jpg
结果告诉我们两个tomcat之间共享了session的内容
我们在试着停掉其中的一台tomcat,然后再请求。没问题还是可以正常工作的。只是所有工作都交给了这一台tomcat执行了。
总结:是不是很简单。可以动手试试哦!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-332882-1-1.html 上篇帖子: Tomcat不完全配置教程(转贴) 下篇帖子: Tomcat Server的组成部分
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表