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

[经验分享] 在win32下apache与tomcat做负载均衡

[复制链接]

尚未签到

发表于 2017-1-9 10:17:55 | 显示全部楼层 |阅读模式
  /**
   *
   *作者:野四abin
   * 时间:2008-12-31
  */
  一、安装apache
  1、下载APACHE
  2、安装APACHE,默认安装就可!
  3、运行APACHE!
  二、安装两个tomcat
  1、下载apache-tomcat-5.5.25.zip解压即可
  2、分别命名这两个tomcat为tomcat1,tomcat2
  3、修改tomcat的配置文件server.xml:
让两个tomcat的shutdown端口,启动端口,Connector ajp端口和Engine的jvmRoute都不相同,并且把server.xml中如下代码:

修改参考:
tomcat1的server.xml需要修改的地方:
<Server port=”8005″ shutdown=”SHUTDOWN”>改为
<Server port=”8015″ shutdown=”SHUTDOWN”>
<Connector port=”8009″ protocol=”AJP/1.3″ redirectPort=”8443″ />改为
<Connector port=”8019″ protocol=”AJP/1.3″ redirectPort=”8443″ />
<Engine name=”Catalina” defaultHost=”localhost”>改为
<Engine name=”Standalone” defaultHost=”localhost” jvmRoute=”worker1″>
tomcat2的server.xml修改:
<Server port=”8005″ shutdown=”SHUTDOWN”>改为
<Server port=”8025″ shutdown=”SHUTDOWN”>
<Connector port=”8009″ protocol=”AJP/1.3″ redirectPort=”8443″ />改为
<Connector port=”8029″ protocol=”AJP/1.3″ redirectPort=”8443″ />
<Engine name=”Catalina” defaultHost=”localhost”>改为
<Engine name=”Standalone” defaultHost=”localhost” jvmRoute=”worker2″>
做好这些修改后两个tomcat就可以同时启动了。其中红色部分是用来做tomcat集群!

修改2个Tomcat的bin下面的catalina.bat和startup.bat(主要是针对免安装版TOMCAT),修改如下:

在startup.bat中加入第一行前面
SET CATALINA_HOME = "您的TOMCAT位置"
在catalina.bat中加入第一行前面
SET CATALINA_BASE = "您的TOMCAT位置"
SET CATALINA_HOME = "您的TOMCAT位置"
SET CATALINA_OPTS = -Xms256m -Xmx768m
其中CATALINA_OPTS设置你的TOMCAT内存大小
  
  三、配置tomcat与apache通信,我用的是mod_jk1.24.so
  1、下载mod_jk1.24.so
  2、把下载好的so重命名为mod_jk.so 并放到apache的modules内。
  3、开始配置 mod_jk:
JK 的配置最关键的有三个文件,分别是
httpd.conf
Apache 服务器的配置文件,用来加载 JK 模块以及指定 JK 配置文件信息
workers.properties
到 Tomcat 服务器的连接定义文件
uriworkermap.properties
URI 映射文件,用来指定哪些 URL 由 Tomcat 处理,你也可以直接在 httpd.conf 中配置这些 URI,但是独立这些配置的好处是 JK 模块会定期更新该文件的内容,使得我们修改配置的时候无需重新启动 Apache 服务器。
其中第二、三个配置文件名都可以自定义。下面是一个典型的 httpd.conf 对 JK 的配置

# (httpd.conf 文件中加入)
# 加载 mod_jk 模块
LoadModule jk_module modules/mod_jk.so
#
# Configure mod_jk
#
JkWorkersFile conf/workers.properties
JkMountFile conf/uriworkermap.properties
JkLogFile logs/mod_jk.log
JkLogLevel warn
接下来我们在 Apache 的 conf 目录下新建两个文件分别是 workers.properties、uriworkermap.properties。这两个文件的内容大概如下:
#
# workers.properties
#
# list the workers by name
worker.list=loadbalancer, status
# localhost server 1
# ————————
worker.worker1.port=8019
worker.worker1.host=localhost
worker.worker1.type=ajp13
# localhost server 2
# ————————
worker.worker2.port=8029
worker.worker2.host=localhost
worker.worker2.type=ajp13
worker.worker2.stopped=1
worker.loadbalancer.type=lb
worker.retries=3
worker.loadbalancer.balanced_workers=worker1, worker2
worker.loadbalancer.sticky_session=1
worker.status.type=status

 
以上的 workers.properties 配置就是我们前面那个屏幕抓图的页面所用的配置。首先我们配置了两个类型为 ajp13 的
worker 分别是 worker1 和 worker2,它们指向同一台服务器上运行在两个不同端口 8019 和 8029 的 Tomcat
上。接下来我们配置了一个类型为 lb(也就是负载均衡的意思)的 worker,它的名字是 loadbalancer,这是一个逻辑的
worker,它用来管理前面配置的两个物理连接 worker1 和 worker2。最后还配置了一个类型为 status 的 worker,这是用来监控 JK
本身的模块。有了这三个 worker 还不够,我们还需要告诉 JK,哪些 worker 是可用的,所以就有 worker.list = loadbalancer, status 这行配置。
接下来便是 URI 的映射配置了,我们需要指定哪些链接是由 Tomcat 处理的,哪些是由 Apache 直接处理的,看看下面这个文件你就能明白其中配置的意义

## uriworkermap.properties
/*=loadbalancer
!//jkstatus=status
!/*.gif=loadbalancer
!/*.jpg=loadbalancer
!/*.png=loadbalancer
!/!/*.css=loadbalancer
!/*.js=loadbalancer
!/*.htm=loadbalancer
!/*.html=loadbalancer

 
所有的请求都由 DLOG4J 这个 worker 进行处理,但是有几个例外,/jkstatus 请求由 status 这个 worker
处理。另外这个配置中每一行数据前面的感叹号是什么意思呢?感叹号表示接下来的 URI 不要由 JK 进行处理,也就是 Apache
直接处理所有的图片、css 文件、js 文件以及静态 html 文本文件。当apache在自己的ServerRoot目录找不到.js,.html等文件时,它会再去请求tomcat来处理。
  四、tomcat集群
  一些人希望所有的tomcat都共享同一个session,所以就要用到集群!

运维网声明 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-325881-1-1.html 上篇帖子: (转)Apache 中 KeepAlive 配置的合理使用 下篇帖子: RHEL5整合Apache+Tomcat,支持jsp与php
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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