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

[经验分享] 基于apache的tomcat负载均衡与集群

[复制链接]

尚未签到

发表于 2017-1-10 11:45:56 | 显示全部楼层 |阅读模式
在之前的项目中使用过IBM的websphere进行负载均衡的配置,鉴于websphere过于沉重与激活问题,尝试使用tomcat进行集群分布,从而实现负载均衡(即由多台服务器来分担访问量,这样在一个服务器上的压力就会减小很多,你可以根据自己的需求去配置任意多的服务器来支撑你的应用系统,如果一台服务崩溃了,那么另外的应用服务器依然可以继续支持应用继续服务。)
   为了实现负载均衡,就自然产生两个问题,
1、如何在多台服务器之间进行session共享,保证一台宕机的情况下另外的服务器可以正常运行(该问题在下文中论述tomcat的会话复制问题),2、如何对访问请求进行分配到不同的服务器。对于这两个问题,我们就需要有一个负责负载均衡的web服务器去完成请求的分配与session的共享(本文暂不对此原理进行讨论)。
  对于apache服务器和tomcat的连接方法了解到有三种:mod_JK、http_proxy和ajp_proxy.本文针对mod_jk进行学习,由于条件有限,不在不同的服务器上进行集群垂直分布,而采用同一台服务器端口号不同的方式进行集群水平分布,
使用的环境配置为:apache 2.4 + tomcat 7 + mod_jk2.4.17进行集群分布式管理
安装包下载:http://www.apachelounge.com/download/;
具体配置步骤如下:
1、apache2.4安装注册,从官网下载压缩包,解压进入bin目录,cmd模式进入该目录进行服务注册:httpd.exe -k install;(注意管理员模式防止注册失败)。注册完成后如图1:
2、安装tomcat。官网直接下载tomcat,修改文件名tomcat1复制并修改tomcat2;
3、使用mod_jk进行集群管理:
    a、在apache24/conf目录下新建workers.properties文件,管理容器列表,内容如下:
            worker.list = controller,tomcat1,tomcat2  #server 列表   
#========tomcat1========   
worker.tomcat1.port=8019       #ajp13 端口号,在tomcat下server.xml配置,默认8009   
worker.tomcat1.host=localhost  #tomcat的主机地址,如不为本机,请填写ip地址    (若垂直分布则在此修改不同的主机地址)
worker.tomcat1.type=ajp13   
worker.tomcat1.lbfactor = 1    #server的加权比重,值越高,分得的请求越多   
#========tomcat2========   
worker.tomcat2.port=8029       #ajp13 端口号,在tomcat下server.xml配置,默认8009   
worker.tomcat2.host=localhost  #tomcat的主机地址,如不为本机,请填写ip地址   
worker.tomcat2.type=ajp13   
worker.tomcat2.lbfactor = 2    #server的加权比重,值越高,分得的请求越多   
#========controller,负载均衡控制器========   
worker.controller.type=lb   
worker.controller.balanced_workers=tomcat1,tomcat2   #指定分担请求的tomcat   
worker.controller.sticky_session=1    b、在apache24/conf目录下新建mod_jk.conf文件,进行负载均衡配置,内容如下:
            #加载mod_jk Module  
LoadModule jk_module modules/mod_jk.so
#指定 workers.properties文件路径  
JkWorkersFile conf/workers.properties  
#指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器  
JkMount /* controller      c、在apache24/conf目录下httpd.conf中增加mod_jk.conf文件的管理:
            文件末尾加入:include conf/mod_jk.conf。
4、修改tomcat1、tomcat2端口设置conf/server.xml(若不同服务器集群垂直分布,即每台服务器只安装一个tomcat则不需要修改):
        --<Connector port="8019" protocol="AJP/1.3" redirectPort="8443" />---与workers.properties中对应分别修改为8019/8029;
--<Server port="8105" shutdown="SHUTDOWN">---port修改 进行区分8105/8205,默认为8005
--<Connector port="8180"                                       ----port修改为8180/8280,默认为8080;5、将编译好的web项目分别放入tomcat下webapps目录下,启动apache、tomcat1、tomcat2。访问http://127.0.0.1/test/index.jsp观察tomcat1与2的测试情况如下图2

△过程中遇到的问题及注意点:
1、本文中的测试是采用水平分布
2、apache启动:通过bin目录下的ApacheMonitor.exe,进行服务管理,若启动失败,则可能是如下问题:
        a、apache默认的80端口被占用,检查方法:cmd命令下:netstat -ano,若存在80端口则根据PID查询该端口的被占用程序进行相关处理,本文中该端口被SQL server reporting services(SQLEXPRESS)占用,解决为关闭改服务;
        b、apache24/conf/httpd.conf中apache24的路径配置不正确。问题原因查询:在运行下输入event选择事件查看器,通过查看日志定位错误
        c、mod_jk与apache版本不匹配,解决方法:下载匹配的关联版本。

运维网声明 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-326552-1-1.html 上篇帖子: javax.xml.transform.TransformerFactoryConfigurationError: Provider org.apache.xa 下篇帖子: php 伪静态 (url rewrite mod_rewrite 重写) 本地APACHE支持urlrewrite 本地APACHE支持.htaccess
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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