设为首页 收藏本站
查看: 772|回复: 0

[经验分享] apache+tomcat集群初探

[复制链接]

尚未签到

发表于 2016-12-31 10:05:46 | 显示全部楼层 |阅读模式
  ubuntu下面进行apache+tomcat集群:
  1.下载httpd-2.2.19.tar.gz和

apache-tomcat-7.0.20.tar.gz


  2.安装apache httpd
  先解压:tar -zxvf httpd-2.2.19.tar.gz

  切换目录:cd httpd-2.2.19

  安装:

./configure --enable-mods-shared='proxy proxy_ajp proxy_balancer proxy_connect proxy_ftp proxy_http proxy_rewrite'
  注:如果

现错误提示:checking whether to enable mod_deflate... configure: error:
mod_deflate has been requested but can not be built due to prerequisite
failures

 zlib-devel 没装的原因:

 apt-get install zlib1g-dev




make
 
make install
修改apache的配置文件/usr/local/apache2/conf/httpd.conf:Listen 80 修改为9999. 非root用户默认是不能用80端口。

 

测试是否安装成功:


#/usr/local/apache2/bin/httpd –k start

  
打开浏览器,输入:http://localhost:9999

,显示“It works
”,安装成功。

  3.安装两个tomcat
  解压apache-tomcat-7.0.20.tar.gz。复制为tomcat1,tomcat2


  4.修改tomcat2中的端口不要和tomcat1重复。
  5.修改tomcat1/conf/server.xml文件:
  1、找到<Engine name="Catalina" defaultHost="localhost">,修改成<Engine name="Catalina" defaultHost="localhost"
  jvmRoute="tomcat1"







>

  2、在Engine
标签内,加入以下:


<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"
channelSendOptions="8">
<Manager className="org.apache.catalina.ha.session.DeltaManager"
expireSessionsOnShutdown="false"
notifyListenersOnReplication="true"/>
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Membership className="org.apache.catalina.tribes.membership.McastService"
address="228.0.0.4"
port="45564"
frequency="500"
dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="auto"
                      port="4000" <!--tomcat2不要重复这个端口号-->
autoBind="100"
selectorTimeout="5000"
maxThreads="6"/>
<Sender className="org.apache.catalina.tribes.transport.ReplicationTransmitter">
<Transport className="org.apache.catalina.tribes.transport.nio.PooledParallelSender"/>
</Sender>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.TcpFailureDetector"/>
<Interceptor className="org.apache.catalina.tribes.group.interceptors.MessageDispatch15Interceptor"/>
</Channel>
<Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
filter=""/>
<Valve className="org.apache.catalina.ha.session.JvmRouteBinderValve"/>
<Deployer className="org.apache.catalina.ha.deploy.FarmWarDeployer"
tempDir="/tmp/war-temp/"
deployDir="/tmp/war-deploy/"
watchDir="/tmp/war-listen/"
watchEnabled="false"/>
<ClusterListener className="org.apache.catalina.ha.session.JvmRouteSessionIDBinderListener"/>
<ClusterListener className="org.apache.catalina.ha.session.ClusterSessionListener"/>
</Cluster>
   
 
tomcat2做类似的修改,粗字体不要重复即可
  3、修改apache的配置文件/usr/local/apache2/conf/httpd.conf:


    在文件的最后加入以下:

修改apache的配置文件/usr/local/apache2/conf/httpd.conf:
在文件的最后加入以下:
NameVirtualHost 192.168.1.158:9999
<VirtualHost 192.168.1.158:9999>
ServerAdmin abc@163.com
#本机的IP地址
ServerName 192.168.1.158
ServerAlias 192.168.1.158
ProxyPass / balancer://cluster/ stickysession=JSESSIONID|jsessionid nofailover=On
ProxyPassReverse / balancer://cluster/
#ErrorLog "logs/error.log"
#CustomLog "logs/access.log" common
</VirtualHost>
#The ProxyRequests directive should usually be set off when using ProxyPass.
ProxyRequests Off
<proxy balancer://cluster>
BalancerMember ajp://192.168.1.158:8009 loadfactor=1 route=tomcat1 smax=5 max=20 ttl=120 retry=300 timeout=15
BalancerMember ajp://192.168.1.158:9009 loadfactor=1 route=tomcat2 smax=5 max=20 ttl=120 retry=300 timeout=15
ProxySet lbmethod=bytraffic
</proxy>
  注:ajp://192.168.1.158:8009 的端口一定要与对应的tomcat的server.xml中的<Connector port="8009"

 protocol="AJP/1.3" redirectPort="8443" />的端口一致。
  6.测试集群
  1、创建一个java web project,命名为Test

   2、修改web.xml,加入<distributable/>

   3、创建index.jsp页面,内容如下:

<%@ page contentType="text/html; charset=GBK" %>
<%@ page import="java.util.*" %>
<html><head><title>Cluster Test</title></head>
<body>
<%
//HttpSession session = request.getSession(true);
System.out.println(session.getId());
out.println("<br> SESSION ID:" + session.getId()+"<br>");   
// 如果有新的请求,则添加session属性
String name = request.getParameter("name");
if (name != null && name.length() > 0) {
String value = request.getParameter("value");
session.setAttribute(name, value);
}   
out.print("<b>Session List:</b>");   
Enumeration<String> names = session.getAttributeNames();
while (names.hasMoreElements()) {
String sname = names.nextElement();  
String value = session.getAttribute(sname).toString();
out.println( sname + " = " + value+"<br>");
System.out.println( sname + " = " + value);
}
%>
</body>
</html>
  把java web project工程复制到两个tomcat的webapp目录中。启动tomcat:./startup.sh和apache:./httpd -k start。在浏览器中输入:http://localhost:9999/Test/index.jsp
  以上步骤只是为了记录本人的一点操作流程,这年头好记性不如破网络。 DSC0000.gif

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-321900-1-1.html 上篇帖子: tomcat + apache http server配置 下篇帖子: apache通用日志包说明
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表