Apache+Tomcat+mod_jk负载均衡

一.需要的软件

  1.jdk1.5以上

  2.Tomcat6以上

  3.Apache2.2以上 ,地址http://apache.dataguru.cn//httpd/binaries/win32/ ,名称:httpd-2.2.25-win32-x86-no_ssl.msi

  4.jk,地址http://archive.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/win32/jk-1.2.31/ ,名称mod_jk-1.2.31-httpd-2.2.3.so

二.安装Apache,记住安装的目录

三.将mod_jk-1.2.31-httpd-2.2.3.so文件拷入Apache的D:\Apache Software Foundation\Apache2.2\modules 目录下

四.打开Apache的httpd.conf文件,添加外部配置文件引入,在文件的最后面添加。

include "D:\Apache Software Foundation\Apache2.2\conf\mod_jk.conf"

五.创建mod_jk.conf文件,并写入一下配置

1 #加载mod_jk Module
2 LoadModule jk_module modules/mod_jk-1.2.31-httpd-2.2.3.so
3
4 #指定 workers.properties文件路径
5 JkWorkersFile conf/workers.properties
6
7 #指定那些请求交给tomcat处理,"controller"为在workers.propertise里指定的负载分配控制器名
8 JkMount /*.jsp controller

六.在Apache配置文件目录下创建workers.properties文件,并写入配置

#server
worker.list = controller,tomcat1,tomcat2
#========tomcat1========
worker.tomcat1.port=8009   #ajp13 端口号,在tomcat下server.xml配置,默认8009
worker.tomcat1.host=localhost   tomcat的主机地址,如不为本机,请填写ip地址
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1  #server的加权比重,值越高,分得的请求越多 

#========tomcat2========
worker.tomcat2.port=9009
worker.tomcat2.host=localhost
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1

#========controller,负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2 #指定分担请求的tomcat
worker.controller.sticky_session=false #粘性会话
worker.controller.sticky_session_force=1
#worker.controller.sticky_session=1 

七.配置Tomcat

  1.第一个Tomcat不需要修改端口,但是需要放开  

<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
 <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">

其中Engine标签已经开放只需要添加名称jvmRoute="" 这里面的名字需要自己起,要和worker.properties里的名称一样

  2.第二个Tomcat需要改端口,改的目的是为了Tomcat在同一台机器运行不冲突即可,然后在开放上面的两个标签。

八.测试项目

  创建一个动态web项目,新建一个index.jsp文件,内容为

<%@ page contentType="text/html; charset=utf-8" %>
<%@ 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="index.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>

九.在web.xml文件中添加一个标签,表示这个项目是可分配的

<distributable/>

  如果Tomcat所有的项目都需要共享,则在Tomcat的conf/context.xml添加即可

十.将测试项目分别部署到Tomcat上,启动Apache服务,在启动两个Tomcat,启动顺序任意。

  1.在本机访问地址为:http://localhost/项目名称/index.jsp

  2.成功的结果,不管怎样刷新页面SessionID都不变,提交的值不会消失

    ID F219C85735A0F7DE958ED3431BF4BEA1.tomcat2

    ID F219C85735A0F7DE958ED3431BF4BEA1.tomcat1

十一.软件解释

  1.Apache  

    支持最新的HTTP/1.1通信协议
    拥有简单而强有力的基于文件的配置过程
    支持通用网关接口
    支持基于IP和基于域名的虚拟主机
    支持多种方式的HTTP认证
    集成Perl处理模块
    集成代理服务器模块
    支持实时监视服务器状态和定制服务器日志
    支持服务器端包含指令(SSI)
    支持安全Socket层(SSL)
    提供用户会话过程的跟踪
    支持FastCGI
    通过第三方模块可以支持JavaServlets

  2.jk

    mod_jk 简称JK,是Apache服务器的一个可插入模块,用以为Apache或IIS服务器提供处理JSP/Servlet的能力。

    Tomcat本身也可以作为Web服务器使用,但是其功能远不及Apache强大,所以Tomcat往往作为JSP/Servlet容器使用

    mod_jk实质上是Apache与Tomcat的连接器,并藉此附带提供集群和负载均衡的功能。

  3.Tomcat+Apache+mod_jk集成

     实现了负载均衡。

       跨平台。

     优势:配置简单,避免了编译webapp.so的麻烦,

     缺点:在linux下找mod_jk不容易,mod_jk已经不再更新

    

时间: 2024-11-05 14:49:31

Apache+Tomcat+mod_jk负载均衡的相关文章

Apache+Tomcat实现负载均衡

反向代理负载均衡 (Apache2+Tomcat7/8) 使用代理服务器可以将请求转发给内部的Web服务器,让代理服务器将请求均匀地转发给多台内部Web服务器之一上,从而达到负载均衡的目的.这种代理方式与普通的代理方式有所不同,标准代理方式是客户使用代理访问多个外部Web服务器,而这种代理方式是多个客户使用它访问内部Web服务器,因此也被称为反向代理模式. 此次使用的代理为mod_proxy的方式来实现的,因为在Apache2以上的版本中已经集成了,因此不需要再另行安装和配置了,只需要把注释去掉

apache+tomcat 搭建负载均衡系统

apache+tomcat+mod_jk 搭建负载均衡系统. 0.os系统采用centos6.8 x64 2.6.32-642.el6.x86_641.首先安装好jdk环境本次采用jdk-8u111-linux-x64.gz  jdk和jre的安装目录要不同,否则的话lib目录下没有dt.jar 和tools.jar  要配置好环境变量如下   vi /etc/profile   #add zwy 2017-08-29   export JAVA_HOME=/home/zhang/java/jd

Linux下Apache+tomcat搭建负载均衡服务器集群

之前在我的博客里面写了一篇文章http://blog.csdn.net/yannanying/article/details/43018175,本文就是为了补充当时的那篇文章而写.我记得当时是参考百度经验里面的一篇文章写的,文章地址为http://jingyan.baidu.com/article/ab0b5630b632dbc15afa7dc4.html,寒假的时候按照这篇文章的相关内容搭建了Apache+tomcat服务器集群,当时是弄成功了,回到学校后再次想尝试一下怎么搭建,但是发现自己记

centos6.5 apache+tomcat结合 负载均衡

一. 负载均衡:根据 uri 表达式把请求分发给各个服务器处理.如:/*.jsp = lb_s  就是说把所有jsp请求交给lb_s , 当然它是个Tomcat. 二. 安装配置mod_jk    mod_jk模块的总体功能 由于tomcat的HTTP处理部分都由Java所写(5.5.12版本以后出现了native库,用以提高其I/O和SSL的性能[1]),在高并发的情况下负载较高.而apache对于静态文件的处理能力比tomcat强,所以tomcat开发组开发了与apache结合使用的mod_

Tomcat的负载均衡(apache的mod_jk来实现)

Tomcat的负载均衡(apache的mod_jk来实现):  1.基于Apache的mod_jk来实现:              apache                /    \            tom1    tom2      在完成两台tomcat1,tomcat2的安装之后,希望可以实现负载均衡,使用mod_jk可以实现节点的故障恢复功能,即一个节点出现问题,mod_jk会其不参与负载, 在节点故障恢复后,mod_jk会让其参与负载,对此节点是否失败,对用户而言是透明的

apache以mod_jk方式实现tomcat的负载均衡集群

目录 1.环境准备 2.mod_jk配置 3.测试 4.总结 1.环境准备 准备三台主机,一台提供httpd环境,另两台提供tomcat环境. 主机规划: 主机名:httpd           IP地址:192.168.0.200提供httpd服务 主机名:TomcatA    IP地址:192.168.0.201提供tomcat服务 主机名:TomcatB    IP地址:192.168.0.202提供tomcat服务 jdk与tomcat的安装请参照博文:http://zhaochj.bl

Apache + Tomcat + mod_jk实现集群服务及session共享

实现效果:用apache 分发请求到tomcat中的对应的项目 原理: 环境说明: 操作系统:win7   64位 Javajdk: 1.7 Apache:httpd-2.2.25-win32-x86-no_ssl.msi    (本地安装路径:D:\Program Files (x86)\Apache2.2\)Tomcat: 7.0.42  ( http://tomcat.apache.org/download-70.cgi ),如果在同一台机器上模拟,下载zip版本. 实例中展示了2个节点m

利用httpd对tomcat进行负载均衡配置

实验系统:CentOS 6.6_x86_64 实验前提:提前准备好编译环境,防火墙和selinux都关闭 实验说明:本实验共有2台主机,IP分配如拓扑 实验软件:jdk-8u60-linux-x64 apache-tomcat-8.0.24 tomcat-connectors-1.2.41 httpd-2.2.15 httpd-devel-2.2.15 实验拓扑: 一.两台机器安装JAVA环境 1.安装JAVA: wget http://download.oracle.com/otn-pub/j

Tomcat(五):nginx/httpd + tomcat及负载均衡tomcat

*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hljs-comment, .hljs-template_comment, .diff .hljs-header, .hljs-javadoc { color: #998; font-style: italic; } .hljs-keyword, .css .rule .hljs-keyword, .h