`
awdxzc
  • 浏览: 333046 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

Apache + Tomcat 实现简单集群

    博客分类:
  • J2EE
 
阅读更多

如上图所示,主要通过Apache-Server作为中转服务器,实现多个tomcat服务器之间的分布式处理,用户直接请求Apache-Server,然后Apache-Server会将请求分发到具体的tomcat-server,之后tomcat-server响应客户请求并返回结果到Apache-Server,最后Apache-Server返回结果给用户

mod_jk.conf

主要定义mod_jk模块的位置以及mod_jk模块的连接日志设置,还有定义worker.properties文件的位置。


worker.properties
定义worker的参数,主要是连接tomcat主机的地址和端口信息。如果Tomcat与apache不在同一台机器上,或者需要做多台机器上tomcat的负载均衡只需要更改worker.properties文件中的相应定义即可。

%APACHE_HOME%为你的安装目录


准备软件:

Jdk1.6

下载地址:http://java.sun.com

tomcat -6.0.29

下载地址:http://jakarta.apache.org

apache_2.2.4-win32-x86-no_ssl.msi

下载地址:http://httpd.apache.org/download.cgi

mod_jk-1.2.31-httpd-2.0.52.so (主要作用是建立Apache Server与Tomcat之间的连接)

下载地址:http://www.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/

说明:apache-server安装完成后,可以在浏览器中输入http://localhost/来测试,如果出现” It works!”则表示安装成功。


安装mod_jk连接模块:
安装好Jdk、tomcat、apache后,加入mod_jk连接模块,就是把mod_jk-1.2.31-httpd-2.2.3.so文件拷贝到%APACHE_HOME%\modules下,把jk模块的配置放到单独的文件中来,在%APACHE_HOME%\conf目录新建mod_jk.conf、worker.properties文件。

保证mod_jk-1.2.31-httpd-2.2.3.so 和 apache 版本一致

在httpd.conf最后加上:

# JK module settings

Include conf/mod_jk.conf  


说明:以上表示将mod_jk.conf配置文件包含进来


修改mod_jk.conf文件:
为了保持httpd.conf文件的简洁,把jk模块的配置放到单独的文件中来。

      

在mod_jk.conf文件中添加以下内容:

# Load mod_jk2 module

LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so

 

# Where to find workers.properties(引用workers配置文件)

JkWorkersFile conf/workers.properties

 

# Where to put jk logs(log文件路径)

JkLogFile logs/mod_jk2.log

 

# Set the jk log level [debug/error/info](log级别)

JkLogLevel info

      

# Select the log format(log格式)

JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "

# JkOptions indicate to send SSL KEY SIZE,

JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories

 

# JkRequestLogFormat set the request format

JkRequestLogFormat "%w %V %T"

 

# Send JSPs for context / to worker named loadBalancer(URL转发配置,匹配的URL才转发到tomcat进行处理)

JkMount /*.jsp controller

# JkMount /*.* loadBalancer


修改workers.properties文件:

在workers.properties文件中添加以下内容:

#server 列表

worker.list = controller,tomcat1,tomcat2

 

# tomcat1(ajp13 端口号,在tomcat下server.xml配置,默认8009)

worker.tomcat1.port=8009

#tomcat的主机地址,如不为本机,请填写ip地址

worker.tomcat1.host=localhost

worker.tomcat1.type=ajp13

#server的加权比重,值越高,分得的请求越多

worker.tomcat1.lbfactor = 1

 

# tomcat2

worker.tomcat2.port=9009

worker.tomcat2.host=localhost

worker.tomcat2.type=ajp13

worker.tomcat2.lbfactor = 1

 

# controller(负载均衡控制器)

worker.controller.type=lb

# 指定分担请求的tomcat

worker.controller.balanced_workers=tomcat1,tomcat2

#worker.controller.sticky_session=true


切记:port 是tomcat对应的ajp13指定的端口

说明:此文件配置了2个tomcat服务器进行负载均衡处理,sticky_session表述是否将对SESSION ID的请求路由回到相同的Tomcat worker。如果属性值不为0,它将被设置为JK_TRUE,session将是粘性的,即SESSION ID的请求路由回到相同的Tomcat worker;当Tomcat正使用能够跨越多个Tomcat实例持久化session数据的Session Manager时,它将被设置为JK_FALSE


修改tomcat配置文件server.xml:






编写一个测试页面teat1.jsp:

<%@ page language="java" contentType="text/html; charset=UTF-8"

    pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<title>test1</title>

</head>

<body>

<% 

   System.out.println("===========================");

%>

</body>

</html>


启动服务器并进行测试:


依次启动apache-server、tomcat1、tomcat2,通过 http://localhost/test/test1.jsp 访问,查看tomcat1的窗口,可以看到打印了一行"==========",再刷新一次,tomcat2也打印了一条,再刷新,可以看到请求会被tomcat1,tomcat2轮流处理,实现了负载均衡




Session复制等相关查见:

引用自http://www.blogjava.net/obpm/archive/2011/06/22/352814.html


有个详细的配置文档提供下载
分享到:
评论
1 楼 natian306 2012-08-02  
虽然lz未配置worker.controller.sticky_session=true,但sticky_session的默认值就是true,所以这样的配置后的结果如果像lz所说的“通过 http://localhost/test/test1.jsp 访问,查看tomcat1的窗口,可以看到打印了一行"==========",再刷新一次,tomcat2也打印了一条,再刷新,可以看到请求会被tomcat1,tomcat2轮流处理”,那么sticky_session所说的相同sessionid的定位到相同路由tomcat就有问题了,sticky_session是这么理解吗?lz的意思呢?

我这里测试均衡,并不能通过点击同一个浏览器才看到期望的结果,而是通过程序一次调用了100次才看到两个tomcat按照配置的权重分摊负载,我这死活测试不出sticky_session想要的结果,lz能指点下吗?

相关推荐

Global site tag (gtag.js) - Google Analytics