上次搞了Apache 2.2的集群方案,但是现在自己的机器和客户的服务器一般都是64位的,而且tomcat已经到8了。重新做Apache 2.4.12 64位+Tomcat-8.0.32-windows-x64负载集群方案。

知其然知其所以然,先看下一些关键术语:

1、负载均衡(load balance)
在互联网高速发展的时代,大数据量、高并发等是互联网网站提及最多的。如何处理高并发带来的系统性能问题,最终大家都会使用负载均衡机制。它是根据某种负载策略把请求分发到集群中的每一台服务器上,让整个服务器群来处理网站的请求。
对于大部分公司,会选择廉价有效的方法扩展整个系统的架构,来增加服务器的吞吐量和处理能力,以及承载能力,或者一些客户不想继续投入,典型啥事扔给研发人员的。

2、集群(Cluster)
 用N台服务器构成一个松耦合的多处理器系统(对外来说,他们就是一个服务器),它们之间通过网络实现通信。让N台服务器之间相互协作,共同承载一个网站的请求压力。

3、高可用(HA)
 在集群服务器架构中,当主服务器故障时,备份服务器能够自动接管主服务器的工作,并及时切换过去,以实现对用户的不间断服务。

4、session复制/共享
 在访问系统的会话过程中,用户登录系统后,不管访问系统的任何资源地址都不需要重复登录,这里面servlet容易保存了该用户的会话(session)。如果两个tomcat(A、B)提供集群服务时候,用户在A-tomcat上登录,接下来的请求web服务器根据策略分发到B-tomcat,因为B-tomcat没有保存用户的会话(session)信息,不知道其登录,会跳转到登录界面。
这时候我们需要让B-tomcat也保存有A-tomcat的会话,我们可以使用tomcat的session复制实现或者通过其他手段让session共享。

Apache +tomcat也有一些不足的地方,或者本博文有配置不对的地方,希望批评指正。以下为个人亲测:

本次全部为64位系统,希望大家配置时版本一致,免得出问题。本次依然使用mod_jk方式。

配置出错:一般有这几种:

1、路径错误;

2、版本错误,尤其jk版本和Apache版本,当大家把mod_jk.so已加载就报错,不加载Apache正常启动的时候就知道是版本不匹配错误;

3、昨天自己配置的时候一个网络问题,在家的内网配置,配置3个tomcat,有一个tomcat部署到了阿里云的一台服务器上,死活tomcat启动不了,启动成功后死活session不共享,后来把这个tomcat挪到内网的一台机器上什么事都没有,这个问题以后再想。

软件架构:

JDK  jdk1.7.0_80 64位 tomcat8需要jdk7及以上支持;

Apache:Apache_HTTP_Server_2.4.12  

tomcat :apache-tomcat-8.0.32-windows-x64

mod_jk:  tomcat-connectors-1.2.40-windows-x86_64-httpd-2.4.x

网络环境:win7,64位,8G内存,一台机器装apache和两个tomcat

软件安装:

在磁盘根目录下安装Apache,安装JDK,复制tomcat81 ,apache82,两个tomcat 都能单独启动;

mod_jk解压出来以后so文件之后,重命名为mod_jk.so,并放到Apache2.4/modules 目录下;

配置:

1、Apache 配置 负载均衡:

    1. 在apache安装目录下conf目录中找到http.conf,在文件最后加上下面一句话就可以了:include "E:\Apache24\conf\mod_jk.conf"
    2. conf同目录新建mod_jk.conf,内容如下:
      1. # 加载jk 模块
        LoadModule jk_module modules/mod_jk.so
        # 设置 worker.properties 文件位置
        JkWorkersFile conf/workers.properties
        # 设置 日志文件文职
        JkLogFile logs/mod_jk.log
        # 设置 日志输出级别 可选项[debug/error/info]
        JkLogLevel debug
        # 转发.jsp 所有的请求到名字为controller的 worker
        JkMount /*.jsp controller

          

    3. conf同目录新建worker.properties,内容如下:
      1. #server列表
        worker.list = controller
        #========tomcat81========
        worker.tomcat81.port=8009 #ajp13端口号
        worker.tomcat81.host=localhost
        worker.tomcat81.type=ajp13
        #server的加权比重,值越高,分得的请求越多
        worker.tomcat81.lbfactor=1 #========tomcat82========
        worker.tomcat82.port=9009
        worker.tomcat82.host=localhost
        worker.tomcat82.type=ajp13
        worker.tomcat82.lbfactor=1 #========controller,负载均衡控制器========
        worker.controller.type=lb
        worker.controller.retries=3
        #指定分担请求的tomcat
        worker.controller.balance_workers=tomcat81,tomcat82
        worker.controller.sticky_session=false
        worker.controller.sticky_session_force=1

        Apache 配置完成,启动Apache,一般来说应该没有问题了,apache 能够正常启动。

  1. 集群配置

    1. 如果是tomcat在不同的两台计算机上,则不用修改,但是要注意原来 的机器上是否在运行着tomcat,防止不改参数做实验你给人家同时给关闭了;
    2. 如果一台机器上两个tomcat,则需要修改一个,我们修改tomcat82:
    3. <Server port="8005" shutdown="SHUTDOWN">改为:
      <Server port="9005" shutdown="SHUTDOWN">
      
    4. <Connector port="8080" protocol="HTTP/1.1"
      connectionTimeout="20000"
      redirectPort="8443" />改为:

          <Connector port="9090" protocol="HTTP/1.1"
      connectionTimeout="20000"
      redirectPort="8443" />
    5. <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />改为:
       <Connector port="9009" protocol="AJP/1.3" redirectPort="8443" />
      
    6. Engine节点, 增加jvmRoute,jvmRoute属性要和worker.properties中balance_workers属性一致,两个tomcat要不同,tomcat81:
        <Engine name="Catalina" defaultHost="localhost"  jvmRoute="tomcat81">
      

        tomcat82:

        <Engine name="Catalina" defaultHost="localhost"  jvmRoute="tomcat82">
      
    7. 集群设置:
      Cluster 节点修改:
        <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"  channelSendOptions="6">
      <Manager className="org.apache.catalina.ha.session.BackupManager"
      expireSessionsOnShutdown="false"
      notifyListenersOnReplication="true"
      mapSendOptions="6"/>
      <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="5000"
      selectorTimeout="100"
      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"/>
      <Interceptor className="org.apache.catalina.tribes.group.interceptors.ThroughputInterceptor"/>
      </Channel>
      <Valve className="org.apache.catalina.ha.tcp.ReplicationValve"
      filter=".*\.gif;.*\.js;.*\.jpg;.*\.png;.*\.htm;.*\.html;.*\.css;.*\.txt;"/>
      <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.ClusterSessionListener"/>
      </Cluster>
      Receiver 节点中的port端口,两台tomcat要不同。
    8. 分别启动tomcat81,tomcat82。
  2. session复制

    1. tomcat/webApps下新建项目test,新建test2.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="test2.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>
    2. 实现session共享,还需要在context.xml添加属性distributable="true",或者像下面的方法
    3. 新建WEB-INF文件夹,文件夹下新建web.xml,内容:
      <web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4">
      <display-name>test</display-name>
      <distributable/>
      </web-app>

        插入<distributable/>

    4. 分别启动tomcat81,tomcat82,分别访问http://localhost:8080/test/test2.jsp,http://localhost:9090/test/test2.jsp
    5. apache 启动,通过 http://localhost/test/test2.jsp 访问,多刷新几次页面,在控制台打印的 session 值都是一致的。可以看到tocmat控制器打印出来的东西,多找几个客户端试试,或者用手机访问下就可以看出来。
  3. 配置完成。

Apache 2.4.12 64位+Tomcat-8.0.32-windows-x64负载集群方案的更多相关文章

  1. win2003 64位系统IIS6.0 32位与64位间切换

    ASP.NET 1.1,32 位版本 要运行 32 位版本的 ASP.NET 1.1,按照以下步骤操作: 1.单击“开始”,单击“运行”,键入 cmd,然后单击“确定”. 2.键入以下命令启用 32 ...

  2. tomcat优化-有改protocol 和 缓存 集群方案

    tomcat优化 在线上环境中我们是采用了tomcat作为Web服务器,它的处理性能直接关系到用户体验,在平时的工作和学习中,归纳出以下七种调优经验. 1. 服务器资源 服务器所能提供CPU.内存.硬 ...

  3. 【转】tomcat优化-有改protocol 和 缓存 集群方案

    tomcat优化 在线上环境中我们是采用了tomcat作为Web服务器,它的处理性能直接关系到用户体验,在平时的工作和学习中,归纳出以下七种调优经验. 1. 服务器资源 服务器所能提供CPU.内存.硬 ...

  4. 64位tomcat不能配32位的JDK使用

    警告: The APR based Apache Tomcat Native library failed to load. The error reported was [D:\apache-tom ...

  5. 64位系统VBS调用32位COM组件

    64位系统VBS调用32位COM组件 标签: 32位, 64位, COM, COM组件, VB, VBS, VBScript 标题: 64位系统VBS调用32位COM组件作者: Demon链接: ht ...

  6. 如何在64位windows7上同时使用32位和64位的Eclipse

    我用的是64位的windows7旗舰版,jdk1.7 64位机器上可以同时运行32位和64位的Eclipse,但是电脑中必须有相应的jdk.Eclipse虽然不需要安装,但是在启动时会检查系统中固定文 ...

  7. CLR调试报错“Visual Studio远程调试监视器 (MSVSMON.EXE) 的 64 位版本无法调试 32 位进程或 32 位转储。请改用 32 位版本”的解决

    Win7 64位电脑上进行visual studio的数据库项目的CLR存储过程进行调试时,报错: ---------------------------Microsoft Visual Studio ...

  8. 64位系统下注册32位dll文件

    64位系统下注册32位dll文件 在64位系统里注册32位软件所需的一些dll会提示不兼容,大概因为32 位进程不能加载64位Dll,64位进程也不可以加载32的导致. 若要支持的32 位和64 位C ...

  9. 64位系统下注册32位dll、ax文件

    64位系统下注册32位dll.ax文件. 换了64位系统遇到的新问题,目前常用的影音处理软件多数为32位. 注册这些32的滤镜会提示不兼容,大概因为32 位进程不能加载64位Dll,64位进程也不可以 ...

随机推荐

  1. 用select实现多客户端连接

    server.c 把accept也看成是一个read类型的函数, 于是我们可以把sockfd也放入到select中 maxi标记当前客户端连接数组的最大下标 select返回值为当前已经准备就绪的fd ...

  2. nginx 日志统计接口每个小时访问量

    指定时间段增量统计nginx日志不同接口的访问量: #!/bin/bash#此脚本用于统计nginx日志当前时间15分钟之内不同接口(URL)的访问量统计LOG=/usr/local/nginx/lo ...

  3. flink批处理中的source以及sink介绍

    一.flink在批处理中常见的source flink在批处理中常见的source主要有两大类: 1.基于本地集合的source(Collection-based-source) 2.基于文件的sou ...

  4. 50.Maximal Square(最大正方形)

    Level   Medium 题目描述: Given a 2D binary matrix filled with 0's and 1's, find the largest square conta ...

  5. Flask-SQLAlchemy使用方法

    Flask-SQLAlchemy使用起来非常有趣,对于基本应用十分容易使用,并且对于大型项目易于扩展.有关完整的指南,请参阅 SQLAlchemy 的 API 文档. 常见情况下对于只有一个 Flas ...

  6. VBA-数据库操作

    基本概念 1 怎么样才能操作数据库?使用ADO建立和数据库的连接,然后用ADO对象和sql语言对数据库进行操作. 2 SQL是什么?SQL(Structured Query Language)是一种查 ...

  7. java中wait()和sleep()的区别

    前言 以前只知道一个结论,但是没法理解,现在水平上来了,自己代码中写了一个验证的方法. 1.先上结论:wait()会释放持有的锁,sleep()不会释放持有的锁 2.验证:看代码运行结果. packa ...

  8. python 发送json数据操作实例分析 - python

    文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习 本文实例讲述了python 发送json数据操作.分享给大家供大家参考,具体如下: # !/usr/bin/env py ...

  9. ubuntu Oracle SQL Developer 安装

    一. 官网下载oracle 安装包 二.下载完毕后,检查你的Ubuntu是否安装了tar和alien sudo apt-get install tar sudo apt-get install ali ...

  10. BZOJ5205 [CodePlus 2018 3 月赛]白金元首与莫斯科

    传送门 emm在雅礼集训的时候听到的一道题 上来就觉得是插头dp 最后果然是轮廓线状压233 我们简化一下题意. 有一个n*m的网格,每个格子是空地或障碍物,询问把每一个空地看成障碍物的情况下,用1* ...