della0887 发表于 2017-1-4 09:36:47

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软件包主要起加载其他模块的作用
# tar xvfz apr-1.2.8.tar.gz
# cd apr-1.2.8
# ./configure --prefix=/usr/local/apr-httpd
# make
# make install
4.  安装 apr-util-1.2.8.tar.gz
# tar xvfz apr-util-1.2.8.tar.gz
# cd apr-util-1.2.8.tar
# ./configure --prefix=/usr/local/apr-util-httpd --with-apr=/usr/local/apr-httpd
# make
# make install
#--prefix=存放路径 --with 是用来加载模块
5. 安装apache
 
root@wljs src]# tar xvfz httpd-2.2.4.tar.gz
# cd 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
# make
# 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
# tar xvfz libtool-1.5.6.tar.gz
# cd libtool-1.5.6
# ./configure
# 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
 
# tar xvf jakarta-tomcat- connectors-1.2.15-src.tar.tar
# cd  到解压目录下面
# ./configure --with-apxs=/usr/local/apache/bin/apxs
# make
# 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,则表明需求会话复制。这就是说,如果你要想进行均衡负载,并在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 需要修改几个地方
 
           
页: [1]
查看完整版本: Liunx 下 apache+tomcat 集群建设1