Liunx 下 apache+tomcat 集群建设1

系统 1819 0

  

 

  测试服务器上的 bbs 我是用 tomcat 跑的,最近两天玩了玩 apache +tomcat 集群,于是准备使用 apache+tomcat 集群重新 部署下我的 bbs 应用,就当理论联系实际吧,使用这个架构方案的好处我就不说了,网上一大堆。

 

 

网络拓扑图

 

 

Liunx 下 apache+tomcat 集群建设1

 

 

 

 

对于来自公网的请求 全部由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

  下载地址:

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

 

[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

 

 

 

 

 

下载地址:

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 需要修改几个地方

 

           

Liunx 下 apache+tomcat 集群建设1


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论