lomg 发表于 2017-1-9 10:17:55

在win32下apache与tomcat做负载均衡

  /**
   *
   *作者:野四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]
查看完整版本: 在win32下apache与tomcat做负载均衡