关于如何搭建Tomcat集群网上还是能搜到很多相关的教程,这里结合我自己在实际应用中的操作做下备忘。

案例说明:

  这里以在本机部署的2个tomcat来做集群。当然,tomcat集群可以是分布式的,而差异也仅仅是在地址-端口的配置上,文章后面会讲到。

部署环境:

操作系统: Red Hat Enterprise Linux Server release 6.0 (Santiago)(x64)
JDK版本: 1.6.0_45

集群构成:

httpd + tomcat + mod_jk

版本选择:

httpd-2.2.
apache-tomcat-7.0.
mod_jk-1.2.-httpd-2.2.3 #这里写的是httpd-2.2.3,但其实跟httpd-2.2.26也能适配

以上文件(都是我从Apache官网下载的)我已经做了打包并上传至百度云盘,需要的朋友可以使用下面的链接下载:

把所需文件上传至服务器以后,我们就可以动手来搭建了。

1.首先安装httpd,过程很简单如下:

#解压httpd包
tar -zxf httpd-2.2..tar.gz
cd httpd-2.2./ #配置预编译选项,这里只关心输出目录就可以了
./configure --prefix=~/apache2
#编译
make
#安装
make install

2.部署tomcat

#解压tomcat包,并复制成2份
tar -zxf apache-tomcat-7.0..tar.gz
mv apache-tomcat-7.0./ tomcat1/
cp -r tomcat1/ tomcat2/

2.1配置tomcat属性,这里以tomcat1、2为例(这里需要注意的地方主要是端口,设置时不要造成冲突即可):

#修改tomcat配置文件server.xml,主要修改:Shutdown端口,Connect服务端口,AJP端口
<Server port="" shutdown="SHUTDOWN">
<Connector port="" protocol="HTTP/1.1" redirectPort="" />
<Connector port="" protocol="AJP/1.3" redirectPort="" />
#修改集群名称和tomcat别名
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">
#去掉cluster节点的注释
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
#修改以上端口是为了避免本机内多个tomcat同时运行造成端口冲突
#修改tomcat配置文件context.xml,为<Context>节点增加distributable="true"属性

同理,tomcat2的配置:

#修改tomcat配置文件server.xml,主要修改:Shutdown端口,Connect服务端口,AJP端口
<Server port="" shutdown="SHUTDOWN">
<Connector port="" protocol="HTTP/1.1" redirectPort="" />
<Connector port="" protocol="AJP/1.3" redirectPort="" />
#修改集群名称和tomcat别名
<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2">
#去掉cluster节点的注释
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
#修改以上端口是为了避免本机内多个tomcat同时运行造成端口冲突
#修改tomcat配置文件context.xml,为<Context>节点增加distributable="true"属性

2.2为tomcat增加个测试文件,后期测试集群性能使用:

<!--编辑webapps/test/test.jsp,主要用来测试负载均衡情况-->

<%@ page contentType="text/html; charset=GB2312" %>
<html>
<head>
<title>tomcat-cluster-test-page</title>
</head>
<body>
SessionID: <%=session.getId() %>
</body>
</html>

OK,基本上tomcat的配置到这里就结束了。

3.为httpd增加集群配置文件

#在apache2/conf/下增加wokers.properties文件
#文件内添加内容,形式如下: #server
worker.list=loadbalancer,jkstatus #tomcat1
worker.tomcat1.port= #该端口是tomcat1的AJP服务端口,设置方式如2.1所示
worker.tomcat1.host=localhost #如果tomcat部署在其他机器上,可填写其服务器IP
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor= #tomcat2
worker.tomcat2.port= #该端口是tomcat2的AJP服务端口,设置方式如2.1所示
worker.tomcat2.host=localhost
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor= #loadbalancer
worker.loadbalancer.type=lb
worker.loadbalancer.balance_workers=tomcat1,tomcat2
worker.loadbalancer.sticky_session=1
worker.jkstatus.type=status

3.1将mod_jk解压到apache2/modules下并命名文件为mod_jk.so,接下来修改配置文件如下:

#编辑apache2/conf/httpd.conf,在底部增加配置:

#加载mod_jk模块
LoadModule jk_module modules/mod_jk.so #指定负载均衡配置文件
JkWorkersFile conf/workers.properties #定义日志输出
JkLogFile logs/mod_jk.log
JkLogLevel debug #mod_jk按照访问路径来做请求分发
#负载均衡的监控页面请求
JkMount /jkstatus jkstatus #将其他任意请求都交由loadbalancer控制器处理
JkMount /* loadbalancer

3.2为httpd手写一个启动控制器:

#!/bin/bash
# file: run.sh
# what: httpd-controller, Usage: run.sh [OPTIONS] <start|status|stop> case "$1" in
start)
/tomcat/apache2/bin/apachectl -f /tomcat/apache2/conf/httpd.conf
echo "apache-httpd started."
;;
stop)
kill -TERM `cat /tomcat/apache2/logs/httpd.pid`
echo "apache-httpd stopped."
;;
status)
if [ -z "`ps -ef|grep httpd|grep -v grep`" ]; then
echo "apache-httpd not started."
else
echo "apache-httpd is running."
fi
;;
*)
echo "Usage: $0 [OPTIONS] <start|stop|status>"
;;
esac

4.启动tomcat和httpd:

tomcat1/bin/startup.sh
tomcat2/bin/startup.sh apache2/bin/run.sh start

启动后,通过浏览器访问下监控页面http://192.168.1.100:8080/jkstatus

访问http://192.168.1.100:8080/test/test.jsp,页面显示正常:

那么我们来找个机器测试下负载均衡性能,测试结果如下:

[tomcat@server ~/test]$for((i=;i<;i++))
> do
> wget http://192.168.1.100:8080/test/test.jsp 2>/dev/null
> done
[tomcat@server ~/test]$awk -F. '/SessionID/{a[$2]++}END{for(i in a){print i, a[i]}}' test.jsp*
tomcat1
tomcat2

从结果来看:负载后,tomcat接收到的请求占比差不多1:1,还是不错的。

关掉tomcat1,然后测试下访问会不会出现问题:

[tomcat@server ~]tomcat1/bin/shutdown.sh
[tomcat@server ~]cd test/
[tomcat@server ~/test]$for((i=;i<;i++))
>do
>wget http://192.168.1.100:8080/test/test.jsp 2>/dev/null
>done
[tomcat@server ~/test]
[tomcat@server ~/test]$awk -F. '/SessionID/{a[$2]++}END{for(i in a){print i, a[i]}}' test.jsp*
tomcat2

OK,所有请求都转发到tomcat2去了,说明节点故障也可以应付。tomcat集群搭建成功。

以上即是tomcat集群搭建的全过程了,文章如有不当之处各位请不吝赐教。

Tomcat集群搭建的更多相关文章

  1. haproxy+tomcat集群搭建

    web1和web2的部署可参考我之前的文章<Tomcat集群搭建>,这里就省去该过程了. #安装haproxy- .tar.gz cd haproxy-/ make TARGET=linu ...

  2. tomcat集群搭建集成nginx负载均衡

    软件基础+版本: 1.3台centos7系统,其中都已经配置完成了jdk环境,jdk的版本为 [root@node03 bin]# java -version java version "1 ...

  3. Centos下Apache+Tomcat集群--搭建记录

    一.目的 利用apache的mod_jk模块,实现tomcat集群服务器的负载均衡以及会话复制,这里用到了<Cluster>. 二.环境 1.基础:3台主机,系统Centos6.5,4G内 ...

  4. Tomcat集群搭建超详细(apache+mod_jk+tomcat)

    TOMCAT集群 目录 TOMCAT集群 1 1 集群 1 1.1 什么是集群 1 1.2 集群的特性 1 1.3 集群的分类 1 1.4 TOMCAT集群配置的优缺点 2 1.5 APACHE+TO ...

  5. solr +zookeeper+tomcat 集群搭建

    最近需要搭建一个cloudSolr集群,写下记录.基础环境是在centos6.5 64bit 3个下载地址: 1. 下载Solr-4.x http://lucene.apache.org/solr/d ...

  6. Niginx +Tomcat 集群搭建

    1 安装niginx服务器,然后启动,访问localhost;出现欢迎界面证明niginx启动成功: 如上图的目录是nginx1.1的目录结构: 2 之后下载tomcat,然后赋值一份,总共两个tom ...

  7. apache搭建Tomcat集群(Cluster)

    搭建集群: apache:特点处理静态资源(html  图片  js等) apache的请求操作,Cluster工具 tomcat:特点处理动态资源 apache+tomcat(apache是web服 ...

  8. Tomcat:基于Apache+Tomcat的集群搭建

    根据Tomcat的官方文档说明可以知道,使用Tomcat配置集群需要与其它Web Server配合使用才可以完成,典型的有Apache和IIS. 这里就使用Apache+Tomcat方式来完成基于To ...

  9. 【原创】搭建Nginx(负载均衡)+Redis(Session共享)+Tomcat集群

    为什么移除首页?哪里不符合要求?倒是回我邮件啊! 一.环境搭建 Linux下Vagrant搭建Tomcat7.Java7 二.Nginx的安装配置与测试 *虚拟机下转至root sudo -i 1)下 ...

随机推荐

  1. 开涛spring3(7.2) - 对JDBC的支持 之 7.2 JDBC模板类

    7.2  JDBC模板类 7.2.1  概述 Spring JDBC抽象框架core包提供了JDBC模板类,其中JdbcTemplate是core包的核心类,所以其他模板类都是基于它封装完成的,JDB ...

  2. Django学习报错记录

    1. 运行manage.py任务  makemigrations时,报错: doesn't declare an explicit app_label and isn't in an applicat ...

  3. DelayQueue使用

    假设现有如下的使用场景: a) 关闭空闲连接.服务器中,有很多客户端的连接,空闲一段时间之后需要关闭之. b) 缓存.缓存中的对象,超过了空闲时间,需要从缓存中移出. c) 任务超时处理.在网络协议滑 ...

  4. The dplyr package has been updated with new data manipulation commands for filters, joins and set operations.(转)

    dplyr 0.4.0 January 9, 2015 in Uncategorized I’m very pleased to announce that dplyr 0.4.0 is now av ...

  5. 最近用django做了个在线数据分析小网站

    用最近做的理赔申请人测试数据集做了个在线分析小网站. 数据结构,算法等设置都保存在json文件里.将来对这个小破站扩充算法,只修改一下json文件就行. 当然,结果分析还是要加代码的.页面代码不贴了, ...

  6. Spring Boot 学习(3)

    文 by / 林本托 Tips 做一个终身学习的人. Tips 代码路径:https://github.com/iqcz/Springbootdemo/tree/master/code01/ch3 W ...

  7. 一个想法照进现实-《IT连》创业项目:直觉型面试招聘的漏洞

    前言: 创业转眼又过去了一个月,是时候抽时间写写文向大伙继续汇报进度了. 还记得上一篇创业文章,我还在说:创业时该不该用新手程序员. 嗯,然后,然后,报应就来了:所以这篇要写写自己在新人招聘上出现的问 ...

  8. Redis 学习之简介及安装

    一.redis简介 Redis是一个开源的,先进的key-value存储.它通常被称为数据结构服务器,因为键可以包含字符串.哈希.链表.集合和有序集合. 支持的数据类型:string(字符串).lis ...

  9. 图表(Chart & Graph)你真的用对了吗?

    欢迎大家持续关注葡萄城控件技术团队博客,更多更好的原创文章尽在这里~~ 工作中,我们常常会遇到各式各样的数据,例如网站性能,销售业绩,客户服务 .营销活动等数据.对于这些数据,有哪些行之有效的方法来形 ...

  10. 常见类——Object

    1.在Java类继承结构中Java.lang.Object类位于顶端   2.如果定义一个Object类没有使用extends关键字声明其父类,则其父类为Java.lang.Object类   3.O ...