apache2.2+tomcat集群

   今天闲来无事,可是又不想浪费大好光阴,因此就弄了一下很久之前就像试试的tomcat 服务器集群,之间一直弄不明白apache与tomcat之间有什么区别,就是知道tomcat是apache基金组织的一个产品,后来专门在网上查了一下,才发现他们区别大发了。

联系:1,apache是普通的服务器,本身只支持html纯网页访问,可以通过插件支持php,还可以与tomcat联通(apache单向连接tomcat,反之不然)2,apache只支持静态网页,但是像jsp asp php等动态网页则需要tomcat来处理。3,apache与tomcat整合使用:如果客户端请求的是静态页面,则只需要apache服务器响应请求,如果客户端请求的是动态页面,则是tomcat服务器响应请求,将jsp等网页代码解析后传给apache服务器,再经apache返回给浏览器。tomcat负责解析动态页面代码,apache负责回传解析好的静态代码,这样tomcat+apache这样整合就减少的tomcat服务器的开销。apache与tomcat是独立的,在同一台服务器上可以集成。

区别:apache是C语言实现的。支持各种特性与模块,从而来扩展核心功能,tomcat是java编写的,更好的支持tservlet与jsp。apache是web服务器,web服务器传送server用于浏览器解析,web服务器用于响应http请求,但应用服务器是通过很多协议为应用提供商业逻辑,tomcat是运行在apache上的应用服务器,应用服务器提供给客户端得是可以供客户端调用的方法,他只是一个servlet容器,可以认为是apache的扩展,但是可以独立于apache运行。apache侧重于http server tomcat侧重于servlet引擎.Apache可以运行一年不重启,稳定性非常好,而Tomcat则不见得。一个很好的例子说明apache与tomcat的就是:apache是一辆车,可以装载html静态页面,但是不能装水,想要装水就必须要有容器,就是tomcat,而这个容器(tomcat)不放在车上同样是可以装水的。

好了,上面扯了那么多算是给自己涨涨知识了,现在开始进入正题。搭建集群所需要的软件:httpd-2.2.25-win32-x86-no_ssl.msi+apache-tomcat-7.0.54-windows-x86.zip,这两个官网上可以很容易的下到,当然还有一个是将两者关联起来的插件mod_jk-1.2.31-httpd-2.2.3.so。稍候我会将这几个东西上传上去。当这些软件都下载后,首先安装apache,只要没有其他的http服务器占用80端口应该很容易的安装成功.我将apache安装在D:\apache2.2目录上。tomcat我采用的并不是最新的tomcat8,而是采用tomcat7,反正从7开始tomcat也就开始支持集群了。下载的是非安装版的,所以直接解压,一个放在D:\tomcat\tomcat1下,一个放在D:\tomcat\tomcat2下面.下面就开始了,很多的东西也都是参考网上别人的博客,在此我这个小菜鸟先谢过被我参考过的各位了。

首先分别修改tomcat conf目录下的server.xml。因为我是在一台电脑上实验的,因此要进行端口号的修改,否则会在启动的时候引起端口的冲突,那么要修改哪些东东呢,别急,慢慢来,首先是关闭端口,我一个设置的8005端口,一个用的是8006端口.

其次是访问端口,我一个改成了8081,一个改成了8082。

最后还有一个要修改的地方:将端口号修改成不同的端口号,将jvmRoute修改成不同的名字,将cluster打开,这个cluster用于session复制。

2,上面的所有操作都是对tomca进行的,接下来是对apache的操作。在D:\apache2.2\conf目录下新建workers.properties文件,内容如下:

#server
worker.list = controller
#========tomcat1========
worker.tomcat1.port=8800
worker.tomcat1.host=localhost
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1
#========tomcat2========
worker.tomcat2.port=8801
worker.tomcat2.host=localhost
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1
#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2
worker.controller.sticky_session=false
worker.controller.sticky_session_force=1
#worker.controller.sticky_session=1

上面飘红的地方对应于最后一张图片的修改的地方。

3,在D:\apache2.2\conf\extra目录下创建mod_jk.conf,内容如下:LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so
JkWorkersFile conf/workers.properties
#指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器名
JkMount /*.jsp controller

mod_jk-1.2.31-httpd-2.2.3.so复制到对应得目录中

4.修改httpd.conf

在D:\apache2.2\下找到conf目录下的httpd.conf,在文件的最后一行添加Include conf/extra/mod_jk.conf。


好啦,接下来就是开始测试了,

建立test项目,需要在项目的web.xml中添加<distributable/>

建立test.jsp,内容如下(网上都用这个测试,我就省的麻烦了):

<%@ page contentType="text/html; charset=GBK" %>

<%@ page import="java.util.*" %>

<html><head><title>Cluster App Test</title></head>

<body>

Server Info:

<%

out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");%>

<%

  out.println("<br> ID " + session.getId()+"<br>");

  // 如果有新的 Session 属性设置

  String dataName = request.getParameter("dataName");

  if (dataName != null && dataName.length() > 0) {

     String dataValue = request.getParameter("dataValue");

     session.setAttribute(dataName, dataValue);

  }

  out.println("<b>Session 列表</b><br>");

  System.out.println("============================");

  Enumeration e = session.getAttributeNames();

  while (e.hasMoreElements()) {

     String name = (String)e.nextElement();

     String value = session.getAttribute(name).toString();

     out.println( name + " = " + value+"<br>");

         System.out.println( name + " = " + value);

   }

%>

  <form action="test.jsp" method="POST">

    名称:<input type=text size=20 name="dataName">

     <br>

    值:<input type=text size=20 name="dataValue">

     <br>

    <input type=submit>

   </form>

</body>

</html>

上面的测试页面就不解释了,很好理解。

Session测试

将项目部署到2个服务器,然后分别启动Apache和2个Tocmat服务器,这些Tomcat启动顺序随意,然后打开http://localhost/test/test,结果.jsp

多次刷新看到sessionid不变,而使用的tomcat会发生变化,打开多个窗口,session中的数据可以共享,则说明成功了









  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值