测试服务器上的bbs 我是用tomcat跑的,最近两天玩了玩apache +tomcat 集群,于是准备使用apache+tomcat 集群重新 部署下我的bbs应用,就当理论联系实际吧,使用这个架构方案的好处我就不说了,网上一大堆。
网络拓扑图
对于来自公网的请求 全部由apache处理,分发给后面的tomcat 集群,这样就实现了负载均衡
安装篇
1. 实验环境
JRE : 1.5.0
Linux : redhat-release-4AS-5.5
Tomcat : tomcat-6.0.18
Apache : Apache/2.2.4
由于实验条件艰苦 我是在一台机子上安装 apache+2tomcat+mysql的
2. 首先安装jre 的安装很简单,我就不说了网上有教程,我的机子上本来就有jre
3. 安装apr包 :
# 在APACHE的搭建中apr软件包主要起加载其他模块的作用
[root@wljs src]# tar xvfz apr-1.2.8.tar.gz
[root@wljs src]# cd apr-1.2.8
[root@wljs apr-1.2.8]# ./configure --prefix=/usr/local/apr-httpd
[root@wljs apr-1.2.8]# make
[root@wljs apr-1.2.8]# make install
4. 安装 apr-util-1.2.8.tar.gz
[root@wljs src]# tar xvfz apr-util-1.2.8.tar.gz
[root@wljs src]# cd apr-util-1.2.8.tar
[root@wljs apr-util-1.2.8.tar]# ./configure --prefix=/usr/local/apr-util-httpd --with-apr=/usr/local/apr-httpd
[root@wljs apr-util-1.2.8.tar]# make
[root@wljs apr-util-1.2.8.tar]# make install
#--prefix=存放路径 --with 是用来加载模块
5. 安装apache
root@wljs src]# tar xvfz httpd-2.2.4.tar.gz
[root@wljs src]# cd httpd-2.2.4
[root@wljs httpd-2.2.4]# ./configure --prefix=/usr/local/apache --enable-mods-shared=all --enable-module=most --with-apr=/usr/local/apr-httpd --with-apr-util=/usr/local/apr-util-httpd --enable-so
[root@wljs httpd-2.2.4]# make
[root@wljs httpd-2.2.4]# make install
#--enable 是加载动态模块 (其中--with-apr=/us……可写也可以不写)
出现问题
checking whether to enable mod_deflate... configure: error: mod_deflate has been requested but can not be built due to prerequisite failures
解决:
安装zlib
http://dinghaoliang.blog.163.com/blog/static/12654071420097254115963/
http://hi.baidu.com/alanlong/blog/item/e6ed4bfb57878a9f59ee90a1.html
使用 rpm -aq zlib 发现其实已经有 zlib-1.2.1.2-1.2 网上说这种情况需要重新安装zlib-1.2.1.2-1.2
重新下载 zlib-1.2.1.2-1.2.src.rpm 需要使用 rpmbuild 命令安装
可是没有rpmbuild命令 于是 安装rpm-build-4.3.3-18_nonptl.i386.rpm 于是在CD3找到
有了 rpmbuild 命令就可以重新安装 zlib 了
6. 安装 libtool-1.5.6.tar.gz
[root@wljs src]# tar xvfz libtool-1.5.6.tar.gz
[root@wljs src]# cd libtool-1.5.6
[root@wljs libtool-1.5.6]# ./configure
[root@wljs libtool-1.5.6]# make & make install
7.安装tomcat 和apache的链接器 jakarta-tomcat-connectors-1.2.15-src.tar.tar
下载地址:
[root@wljs src]# tar xvf jakarta-tomcat- connectors-1.2.15-src.tar.tar
[root@wljs src]# cd 到解压目录下面
[root@wljs native2]# ./configure --with-apxs=/usr/local/apache/bin/apxs
[root@wljs native2]# make
[root@wljs native2]# male install
将 /root/wang/jakarta-tomcat-connectors-1.2.15-src/jk/native/apache-2.0 目录下编译生成的
mod_jk.so 拷贝的apache的安装目录
/usr/local/apache/modules
修改 /usr/local/apache/conf 目录下的 httpd.conf 文件 最后加上
LoadModule jk_module modules/mod_jk.so
出现问题
一开始我使用的链接器 是 jakarta-tomcat-connectors-jk2-2.0.4-src.tar.tar 导致和tomcat集成的时候,apache 启动的时候总是报错,更换了链接器 为 1.2.15 就OK了
下载地址:
集成篇
1. apache 和tomcat 集成主要 体现的几个配置文件上
httpd.conf apache的主要配置文件
新增
Listen 9080
LoadModule jk_module modules/mod_jk.so
#应用程序的上级目录 这个写错会导致css和图片路径不对
DocumentRoot "/usr/local/apache/htdocs"
#首页
DirectoryIndex index.html index.jsp
#apache的安装路径
ServerRoot "/usr/local/apache"
# mod_jk
#include "/usr/local/apache/conf/mod_jk.conf"
JkWorkersFile "conf/workers.properties"
JkLogFile "logs/mod_jk.log"
JkMount /*.jsp controller
JkMount /*.jspx controller
JkMount /servlet/* controller
JkMount /*.do controller
JkMount /dwr/* controller
# JkMount /* controller
workers.properties apache 接受到客户端请求以后如何转发请求,请求过滤的规则,负载因子等
新增
# The advanced router LB worker
worker.list=controller,tomcat1,tomcat2 #server 列表
# Define a worker using ajp13
worker.tomcat1.port=8009
worker.tomcat1.host=localhost
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor=5 #server的加权比重,值越高,分得的请求越多
# Define another worker using ajp13
worker.tomcat2.port=8010
worker.tomcat2.host=localhost
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor=1
# Define the LB worker
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2 #指定分担请求的tomcat
worker.controller.sticky_session=0
以上要说明的是原文中worker.controller.sticky_session=1,等同于 worker.controller.sticky_session=true.此处指定集群是否需要会话复制,如果设为true,则表明为会话粘性,不进行会话复制,当某用户的请求第一次分发到哪台Tomcat后,后继的请求会一直分发到此Tomcat服务器上处理;如果设为false,则表明需求会话复制。这就是说,如果你要想进行均衡负载,并在tomcat1和tomcat2实例上实现集群全局session复制,此处值要设置成false。
tomcat 安装目录的conf 下找到 server.xml 给 <Host></Host> 加上
<Context path="" docBase="/usr/local/apache/htdocs" debug="0" reloadable="true" crossContext="true"/>
docBase="/usr/local/apache/htdocs" 的路径要和 httpd.conf 下的
DocumentRoot "/usr/local/apache/htdocs" 要一致
2. 将tomcat 的安装 目录 拷贝1份 叫 tomcat-6.0.18_01 和tomcat-6.0.18_02
修改配置文件 模拟2个tomcat ,防止端口冲突
Server.xml 需要修改几个地方