Liunx 下 apache+tomcat 集群建设1

  

 

 测试服务器上的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软件包主要起加载其他模块的作用

[[email protected] src]# tar xvfz apr-1.2.8.tar.gz
[[email protected] src]# cd apr-1.2.8
[[email protected] apr-1.2.8]# ./configure --prefix=/usr/local/apr-httpd
[[email protected] apr-1.2.8]# make
[[email protected] apr-1.2.8]# make install

4.  安装 apr-util-1.2.8.tar.gz

[[email protected] src]# tar xvfz apr-util-1.2.8.tar.gz

[[email protected] src]# cd apr-util-1.2.8.tar

[[email protected] apr-util-1.2.8.tar]# ./configure --prefix=/usr/local/apr-util-httpd --with-apr=/usr/local/apr-httpd

[[email protected] apr-util-1.2.8.tar]# make

[[email protected] apr-util-1.2.8.tar]# make install

#--prefix=存放路径 --with 是用来加载模块

5. 安装apache

 

[email protected] src]# tar xvfz httpd-2.2.4.tar.gz

[[email protected] src]# cd httpd-2.2.4

[[email protected] 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

[[email protected] httpd-2.2.4]# make

[[email protected] 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
[[email protected] src]# tar xvfz libtool-1.5.6.tar.gz
[[email protected] src]# cd libtool-1.5.6
[[email protected] libtool-1.5.6]# ./configure
[[email protected] libtool-1.5.6]# make & make install

 

 

7.安装tomcat apache的链接器  jakarta-tomcat-connectors-1.2.15-src.tar.tar

  下载地址:

http://archive.apache.org/dist/jakarta/tomcat-connectors/jk/source/jk-1.2.15/jakarta-tomcat-connectors-1.2.15-src.tar.gz

 

[[email protected] src]# tar xvf jakarta-tomcat- connectors-1.2.15-src.tar.tar
[[email protected] src]# cd  
到解压目录下面

[[email protected] native2]# ./configure --with-apxs=/usr/local/apache/bin/apxs
[[email protected] native2]# make

[[email protected] 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

 

 

 

 

 

下载地址:

http://archive.apache.org/dist/jakarta/tomcat-connectors/jk/source/jk-1.2.15/jakarta-tomcat-connectors-1.2.15-src.tar.gz

集成篇

 

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,则表明需求会话复制。这就是说,如果你要想进行均衡负载,并在tomcat1tomcat2实例上实现集群全局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

修改配置文件 模拟2tomcat ,防止端口冲突

 

Server.xml 需要修改几个地方