开发者社区> 余二五> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

(二)apache+tomcat集群+session会话同步

简介:
+关注继续查看

一、 环境说明

在一台服务器上安装一个apache作为web server,多个tomcat作为应用的容器,此时我们便可以使用apache来作为一个调度员将用来发来的请求发送到不同的tomcat。apache和tomcat1安装到192.168.0.3,tomcat2安装到192.168.0.4
拓扑:
绘图2
二、 原理
tomcat 为一个jsp的容器,apache为一个web server,两者之间通信通过worker进行(由Tomcat使用Server.xml文件中Connector的标签来定义其端口和协议),通过 mod_jk的模块(由web服务器像apache、iis等使用)和Web Server通信。整个过程其实就是让apache的httpd.conf文件调用mod_jk.conf,mod_jk.conf调用workers.properties,最后配置虚拟主机。
   文件说明
mod_jk.conf
主要定义mod_jk模块的位置以及mod_jk模块的连接日志设置,还有定义worker.properties文件的位置。
worker.properties
定义worker的参数,主要是连接tomcat主机的地址和端口信息。如果Tomcat与apache不在同一台机器上,或者需要做多台机器上tomcat的负载均衡只需要更改workers.properties文件中的相应定义即可。
三、 安装软件
1.先安装了所需的程序库
 
yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel
 
2.Apache 安装:
 
tar zxvf httpd-2.2.8.tar.gz
cd httpd-2.2.8
./configure --prefix=/usr/local/apache2 --enable-modules=so --enable-so
make && make install
 
3.JDK的安装
 
chmod 755 jdk-6u26-linux-i586-rpm.bin
./jdk-6u26-linux-i586-rpm.bin
mv /usr/java/jdk1.6.0_26 /usr/local/
到/usr/bin目录下,把原用的java,javac文件删除:
rm -rf /usr/bin/{java,javac}
在/usr/bin 下建立 软连接 java
ln -s /usr/local/jdk1.6.0_26/bin/java /usr/bin/java
ln -s /usr/local/jdk1.6.0_26/bin/javac /usr/bin/javac
javac -version
为了方便下在的工作建立两个软链接:
ln -s /usr/local/jdk1.6.0_26/  /usr/local/jdk
ln -s /usr/local/jdk1.6.0_26/jre /usr/local/jre
4.Tomcat的安装
tar -zxvf apache-tomcat-7.0.16.tar.gz
mv apache-tomcat-7.0.16 /usr/local/tomcat
 
5.设置环境变量:
 
JAVA_HOME=/usr/local/jdk
export JAVA_HOME
JRE_HOME=/usr/local/jre
export JRE_HOME
CLASSPATH=/usr=/usr/local/tomcat/lib/:/usr/local/jdk/lib:/usr/local/jre/lib
export CLASSPATH
PATH=$PATH:/usr/local/tomcat/bin/:/usr/local/apache/bin:/usr/local/jdk/bin:/usr/local/jre/bin
export PATH
TOMCAT_HOME=/usr/local/tomcat
export TOMCAT_HOME
 
6.JK 安装 (整合apache tomcat)
 
tar zxvf tomcat-connectors-1.2.27-src.tar.gz
cd tomcat-connectors-1.2.27-src/native
./configure --with-apxs=/usr/local/apache2/bin/apxs --with-java-home=/usr/local/jdk
sleep 3
make && make install
在/usr/local/apache2/modules/ 下会产生mod_jk.so
 
四、 配置Apache和tomcat
1.修改apache配置文件
include conf/mod_jk.conf
 
2.vi /usr/local/apache2/conf/mod_jk.conf
 
LoadModule jk_module modules/mod_jk.so
JkWorkersFile conf/workers.properties
JkLogFile logs/mod_jk.log
JkShmFile logs/mod_jk.shm
JkLogLevel info
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories
JkRequestLogFormat "%w %V %T"
JkMount /* controller
 
3.调度器JK的配置
建立JK配置文件:
 
vi /usr/local/apache2/conf/workers.properties
worker.list=controller
#========tomcat1========
worker.tomcat1.type=ajp13
worker.tomcat1.port=8009                       //第4步会配置此端口
worker.tomcat1.host=localhost
worker.tomcat1.lbfactor=1
 
#========tomcat2========
worker.tomcat2.type=ajp13
worker.tomcat2.port=8009
worker.tomcat2.host=192.168.0.4
worker.tomcat2.lbfactor=1
 
#========controller,负载均衡器======worker.controller.type=lb
worker.controller.balance_workers=tomcat1,tomcat2  # server.xml配置文件里的jvmRoute="tomcat1"指定的名字
worker.controller.sticky_session=1=
 
4.修改baiying21的tomcat调用端口
vi /usr/local/tomcat/conf/server.xml
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />   //我们使用默认端口8009
修改baiying23的tomcat调用端口
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />  
5. tomcat集群配置
tomcat1配置:
A修改Engine节点信息: <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">
B、去掉<Cluster>  <\Cluster> 的注释符
C、修改Cluster 节点信息
<Membership          
className="org.apache.catalina.cluster.mcast.McastService"
mcastBindAddress="192.168.0.3"              
mcastAddr="224.0.0.1"              
mcastPort="45564"              
mcastFrequency="500"
mcastDropTime="3000"/>
<Receiver         
className="org.apache.catalina.cluster.tcp.ReplicationListener"
tcpListenAddress="192.168.0.3"              
tcpListenPort="4001"              
tcpSelectorTimeout="100"              
tcpThreadCount="6"/>  
 
tomcat2配置:
A、修改Engine节点信息: <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2">
B、去掉<Cluster>  <\Cluster> 的注释符
C、修改Cluster 节点信息
<Membership
className="org.apache.catalina.cluster.mcast.McastService"              
mcastBindAddress="192.168.0.4"              
mcastAddr="224.0.0.1"              
mcastPort="45564"     mcastFrequency="500"              
mcastDropTime="3000"/>
<Receiver         
className="org.apache.catalina.cluster.tcp.ReplicationListener"          
 
tcpListenAddress="192.168.0.4"              
tcpListenPort="4001"              
tcpSelectorTimeout="100"              
tcpThreadCount="6"/>
 
6.session配置
 
修改web应用里面WEB-INF目录下的web.xml文件,加入标签
<distributable/>
直接加在</web-app>之前就可以了
做tomcat集群必须需要这一步,否则用户的session就无法正常使用。
 
注意事项:1、mcastAddr="224.0.0.1"  这主广播地址因此需要开启网卡组播功能
route add -net 224.0.0.0 netmask 240.0.0.0 dev eth0
分别在各机器上运行
 
五、 创建jsp测试页面
在tomcat1安装路径下建立目录test
mkdir /usr/local/tomcat/webapps/ROOT/test/
vi index.jsp
<html>
<title>
tomcat1 jsp
</title>
<%
   String showMessage="Oh My God localhost!";
   out.print(showMessage);
%>
</html>
----------------------------
在tomcat2安装路径下建立目录test
mkdir /usr/local/tomcat/webapps/ROOT/test/
vi index.jsp
<html>
<title>
tomcat2 jsp
</title>
<%
   String showMessage="Oh My God 192.168.0.4!";
   out.print(showMessage);
%>
</html>
 
修改客户端的hosts文件
192.168.0.3 www.baiying21.com
192.168.0.3 www.baiying23.com
在客户端浏览器输入www.baiying21.com/test/index.jsp多次刷新验证apache是否进行轮询成功。




本文转自 baiying 51CTO博客,原文链接:http://blog.51cto.com/baiying/735815,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
tomcat会话之持久化会话管理器
前面提到的标准会话管理器已经提供了基础的会话管理功能,但在持久化方面做得还是不够,或者说在某些情景下无法满足要求,例如把会话以文件或数据库形式存储到存储介质中,这些都是标准会话管理器无法做到的,于是另外一种会话管理器被设计出来——持久化会话管理器。
1056 0
linux下tomcat配置单点登录
环境:公司要求一套综合服务系统配置单点登录功能。 tomcat使用比较新的版本是6.0.35 jdk使用的是1.6版本,详细信息如下图: 至于cas工程怎么得到的我也不太清楚,是开发同事给的。
887 0
tomcat虚拟路径的几种配置方法
tomcat配置虚拟路径的4种方法在tomcat中,webapp文件夹默认为web应用的根目录。1.在tomcat\conf\server.xml中找到 host标签,在host标签中增加新的元素并设置 Context的元素,其中path元素所设置的值就是在浏览器中所要访问的虚拟路径的名称;docBase元素所对应的值就是web应用所在的具体目录,这里既可以的相对webapp的相对路径,也可是文件的绝对路径。
799 0
一台电脑同时运行多个tomcat配置方法
修改安装目录下的conf目录中的server.xml文件:   a.修改http访问端口(默认为8080端口),将8080修改为tomcat不在使用的端口号,例如:8081。此处所设的端口号即是以后访问web时所用的端口号。
670 0
JSP学习中Tomcat服务器的配置的几个问题 适合初学者
    Tomcat  是支持JSP 的一个web 服务器  一个开源的web 服务器  我也是今天刚学习 JSP 一上来 就遇到了问题 就是  Tomcat的配置问题  1.    首先我运行 bin目录下的 startup.bat就会一闪而过然后就没了 反复多次后也没有效果 于是我去baidu  ,      听别人说是我的 JAVA_HOME变量没设置 ,因为 Tomcat是 依靠JDK来运行的 所以如果你下载的是ZIP版本的话 一定要设置JAVA_HOME环境变量      设置完成之后重启下电脑  如果不重启 环境变量不会生效 。
713 0
Tomcat 配置双向 SSL
这几天弄tomcat的ssl双向设置,网上找到了一篇关于tomcat5。5在xp下的设置文档,按照上面的操作了一遍,然后部署,发现不行,在 tomcat5.5里报无法识别的keystore文件类型,操作过程如下: 1.
578 0
使用java内置keytool配置tomcat双向SSL认证
在Tomcat 6中配置SSL双向认证是相当容易的,本文将介绍如何使用JDK的keytool来为Tomcat配置双向SSL认证。 系统需求: JDK 5.0Tomcat 6.0.16 第一步:为服务器生成证书 使用keytool为Tomcat生成证书,假定目标机器的域名是“localhost”,keystore文件存放在“C:\tomcat.
890 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
原生SQL on Hadoop引擎- Apache HAWQ 2.x最新技术解密malili
立即下载
Apache NiFi Crash Course Intro
立即下载
《Apache RocketMQ 源码解析》
立即下载