Apache Httpd负载均衡Tomcat并实现Session Sticky和Session Cluster 大纲

Apache Httpd负载均衡Tomcat并实现Session Sticky和Session Cluster



大纲

前言

  • 实验拓扑
  • 实验步骤
    • 安装配置tomcat
    • 安装配置Apache Httpd并测试
    • 实现session sticky
    • 实现Session Cluster
  • 总结

前言

上篇文章我们介绍如何构建一个LANMT平台并搭建一个jspxcms, 这次我们介绍使用apache httpd负载均衡Tomcat并实现Session StickySession Cluster

实验拓扑

实验步骤

安装配置tomcat

我们首先配置Tomcat, 安装过程这里不做叙述, 不明白的可以看我上篇博客: tomcat基础进阶

安装Tomcatnode2,3都要操作

[[email protected] ~]# [[email protected] ~]# wget http://mirrors.cnnic.cn/apache/tomcat/tomcat-8/v8.0.33/bin/apache-tomcat-8.0.33.tar.gz
[[email protected] ~]# tar xf apache-tomcat-8.0.33.tar.gz  -C /usr/local/
[[email protected] ~]# cd /usr/local ; ln -sv apache-tomcat-8.0.33 tomcat ; cd ~
[[email protected] ~]# wget http://download.oracle.com/otn-pub/java/jdk/8u77-b03/jdk-8u77-linux-x64.rpm #如果下载出错, 使用浏览器下载
[[email protected] ~]# rpm -ivh jdk-8u77-linux-x64.rpm   #安装JDK

[[email protected] ~]# vim /etc/profile.d/java.sh     #定义JAVA_HOME
export JAVA_HOME=/usr/java/latest
export PATH=$JAVA_HOME/bin:$PATH

[[email protected] ~]# vim /etc/profile.d/tomcat.sh    #配置tomcat的环境变量
export CATALINA_BASE=/usr/local/tomcat
export PATH=$CATALINA_BASE/bin:$PATH

[[email protected] ~]# source /etc/profile.d/tomcat.sh
[[email protected] ~]# source /etc/profile.d/java.sh

配置虚拟主机

[[email protected] ~]# vim /usr/local/tomcat/conf/server.xml   

#设置默认虚拟主机为web1.anyisalin.com #node3的jvmRoute设置为TomcatB
<Engine name="Catalina" defaultHost="web1.anyisalin.com" jvmRoute="TomcatA">  

#添加虚拟主机
<Host name="web1.anyisalin.com" appBase="/data/webapps/" unpackWARS="true" autoDeploy="true">
   <Context path="" docBase="/data/webapps" reloadable="true" />
     <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/data/logs"
        prefix="web1_access_log." suffix=".txt"
        pattern="%h %l %u %t &quot;%r&quot; %s %b" />
</Host>

[[email protected] ~]# mkdir -PV /data/webapps/{WEB-INF,META-INF,classes,lib}  #创建目录

node2创建网页文件

[[email protected] ~]# cd /data/webapps/

[[email protected] ~]# vim index.jsp  #创建网页文件
<%@ page language="java" %>
<html>
  <head><title>TomcatA</title></head>
  <body>
    <h1><font color="red">TomcatA.magedu.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("magedu.com","magedu.com"); %>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>
    </table>
  </body>
</html>

[[email protected] webapps]# catalina.sh start #启动tomcat

node3创建网页文件

[[email protected] ~]# cd /data/webapps/

[[email protected] ~]# vim index.jsp  #创建网页文件
<%@ page language="java" %>
<html>
  <head><title>TomcatB</title></head>
  <body>
    <h1><font color="blue">TomcatB.magedu.com</font></h1>
    <table align="centre" border="1">
      <tr>
        <td>Session ID</td>
    <% session.setAttribute("magedu.com","magedu.com"); %>
        <td><%= session.getId() %></td>
      </tr>
      <tr>
        <td>Created on</td>
        <td><%= session.getCreationTime() %></td>
     </tr>
    </table>
  </body>
</html>

[[email protected] webapps]# catalina.sh start #启动tomcat

访问测试

安装配置Apache Httpd并测试

安装httpd 在node1

[[email protected] ~]# yum install httpd -y

配置httpd 
mod_Proxy_balancer模块文档

[[email protected] ~]# cd /etc/httpd/conf.d/

[[email protected] conf.d]# vim virt.conf 
<Proxy balancer://lbcluster>
   BalancerMember ajp://172.16.1.3:8009 loadfactor=1 route=TomcatA
   BalancerMember ajp://172.16.1.4:8009 loadfactor=1 route=TomcatB
</Proxy>

<VirtualHost *:80>
  ServerName www.anyisalin.com
  ProxyVia On
  ProxyRequests Off
  ProxyPassReverse / balancer://lbcluster/
  ProxyPass / balancer://lbcluster/
</VirtualHost>

[[email protected] conf.d]# service httpd start  #启动httpd

测试负载均衡效果

实现session sticky

如果tomcat运行着一个动态站点, 那么上面这种byrequest的负载均衡调度算法就有很大问题了, 可能刚登录站点再刷新又回到没有登录的状态了, 所以我们就要实现session sticky, 其实session sticky就是我们之前lvs的sh算法, 和nginxip_hash实现的效果

编辑httpd配置文件

[[email protected] ~]# vim /etc/httpd/conf.d/virt.conf   
## 主要添加两段参数
##Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED
##ProxySet stickysession=ROUTEID 

Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED #新添加的
<Proxy balancer://lbcluster>
   BalancerMember ajp://172.16.1.3:8009 loadfactor=1 route=TomcatA
   BalancerMember ajp://172.16.1.4:8009 loadfactor=1 route=TomcatB
   ProxySet stickysession=ROUTEID  #新添加的
</Proxy>

<VirtualHost *:80>
  ServerName www.anyisalin.com
  ProxyVia On
  ProxyRequests Off
  ProxyPassReverse / balancer://lbcluster/
  ProxyPass / balancer://lbcluster/
</VirtualHost>

[[email protected] conf.d]# service httpd restart   #重启httpd

测试session sticky效果 
如下图, 我们成功的将session绑定在了TomcatA(Node2)主机上

实现Session Cluster

我们使用session sticky会有很多问题, 如果某台主机宕机了, 那么用户的session就丢失了, 所以我们还可以通过session cluster保存用户会话

什么是Session Cluster

正常情况下session信息是保存在用户所访问的服务器上,服务器宕机, 用户的session就丢失了, 但是我们可以通过session cluster的方式来实现将用户的session信息保存在后端所有的服务器上, 这样来, 无论用户在访问哪一台服务器,session都不会丢失

四种常见的session manager

  • StandardManager
  • PersistentManager: 可以将session信息保存在持久存储中
  • DeltaManager: 将session信息通过多播的形式共享到其他节点
  • BackupManager: 将session信息共享到特定的一个节点上

注意: 我们要删掉刚才对session sticky的配置

编辑tomcat作配置文件

[[email protected] conf]# vim server.xml
下列内容放在<Host />内

<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.1.7"
         port="45564"
         frequency="500"
         dropTime="3000"/>
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
          address="auto"
          port="4000"
          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.ClusterSessionListener"/>
</Cluster>

配置WEB-INF中的web.xml文件

[[email protected] conf]# cd /data/webapps/
[[email protected] webapps]# cp /usr/local/tomcat/webapps/ROOT/WEB-INF/web.xml WEB-INF/  #拷贝一份模板
[[email protected] webapps]# vim WEB-INF/web.xml
#添加下面这一行,在</web-app>内
<distributable/>

##注意: 这里是node3
[[email protected] webapps]# scp node2.anyisalin.com:/usr/local/tomcat/conf/server.xml /usr/local/tomcat/conf/server.xml  #复制node2配置文件
[[email protected] webapps]# scp node2.anyisalin.com:/data/webapps/WEB-INF/web.xml /data/webapps/WEB-INF/ 

[[email protected] webapps]# catalina.sh stop  #重启tomcat
[[email protected] webapps]# catalina.sh start 

[[email protected]  webapps]# catalina.sh stop  #重启tomcat
[[email protected] webapps]# catalina.sh start

session cluster测试 
如下图, 现在我们即使使用byrequests算法也不会丢失sesssion

总结

我们本文实现了tomcat的负载均衡和session保持的各种方法, 但是还是有很大问题, 我们试想在用户并发高的场景下, 多台tomcat服务器一直在多播, 很可能造成网络拥塞, 所以我们还有一种解决方案session server, 使用单台服务器保存用户的session信息, 我们会在下篇文章向大家介绍!

作者水平很低, 如果有错误及时指出, 如果你觉得本文写的好请点一波赞~(≧▽≦)/~ 
作者: AnyISaIln QQ: 1449472454 
感谢: MageEdu

时间: 2024-08-08 07:47:48

Apache Httpd负载均衡Tomcat并实现Session Sticky和Session Cluster 大纲的相关文章

高性能Web服务之Httpd负载均衡Tomcat实现Session Sticky及Session Cluster

Httpd负载均衡Tomcat实现Session Sticky及Session Cluster架构如下所示: 实现过程如下: 配置tomcat服务(tomcat1\tomcat2) (1)安装JDK # rpm -ivh jdk-7u9-linux-x64.rpm  --安装JDK后生成的文件 # cd /usr/java/ ; ll total 4 lrwxrwxrwx  1 root root   16 Sep 27 09:09 default -> /usr/java/latest drw

haproxy、nginx以及httpd负载均衡tomcat主机,seesion保持问题

**实验环境** CentOS 7 haproxy(nginx):172.16.61.4(node4) httpd+tomcat:172.16.61.7(node7) 172.16.61.8(node8) 一.使用nginx做负载均衡 **配置tomcat以及httpd** <Engine name="Catalina" defaultHost="localhost" jvmRoute="Tomcat8">   #在node8节点添加

apache基于mod_jk模块实现代理及负载均衡Tomcat Cluster

一.基于mod_jk模块实现apache代理tomcat 上篇博文已经学习了nginx代理和负载均衡tomcat及apache基于mod_proxy模块代理tomcat; 现在来学习下apache基于mod_jk模块实现代理及负载均衡Tomcat Cluster 1.基于httpd代理tomcat时可以使用httpd的两个模块 1)mod_jk:第三方模块 mod_jk是ASF的一个项目,是一个工作于apache端基于AJP协议与Tomcat通信的连接器,它是apache的一个模块,是AJP协议

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

tomcat结合nginx或apache实现负载均衡

基于Nginx为web代理服务器配置 前端Nginx配置: yum -y install nginx-1.4.7-1.el6.ngx.x86_64.rpm vim /etc/nginx/nginx.conf 添加一下内容 upstream tomcat { 定义一个名为tomcat的upstream server 172.16.254.151:80; server 172.16.254.144:8080; } 编辑/etc/nginx/conf.d/default.conf配置文件 启动ngin

Apache配置负载均衡-实例

公司两台服务器都安装了tomcat,配置apache作为负载均衡,当一台服务器出现故障时还能保证业务正常运行. Server1:192.168.1.100 Server2:192.168.1.200 1.查询是否已经安装了apache rpm -qa | grep httpd 2.使用yum安装apache,负载配置是一样的. yum -y install httpd* 3.启动apache,设置为开机自启动. systemctl start httpd systemctl enable htt

再谈Apache ActiveMQ 负载均衡

前面文章<Apache ActiveMQ 负载均衡 >在最后有提到一个场景,就是当AMQ的节点数大于2个的时候(HA + LB),且配置了消息回流的情况下的一些问题. HA + LB的基本结构如下图: 问题即发生在当生产者将消息投递到Master节点后(AMQ SERVER),消费者与A节点建立连接(Broker),根据AMQ的"预先消费"策略预先消费了一定数量的消息,即A节点消费了Master节点的一部分消息,A节点在将消息转发至消费者Consumer. 消费者在消费过程

[转帖]利用nginx实现负载均衡 | 哈希算法,sticky模块实现session粘滞

利用nginx实现负载均衡 | 哈希算法,sticky模块实现session粘滞 2018年08月02日 10:06:03 Minza 阅读数 483 https://blog.csdn.net/ha_weii/article/details/81350087 学习一下如何使用sticky 版权声明:创作不易,转载请注明出处 https://blog.csdn.net/ha_weii/article/details/81350087 一,普通的负载均衡 1,启动nginx服务器 之前已经把/us

tomcat+Apache+jk负载均衡集群配置方法

一.需要软件:tomcat6.0+apache2.2+mod_jk(符合apache2.2的,apache官网有下载...) 二.参考:略 三.环境:多台服务器. 四.安装. 主机A:apache,tomcatA,ip:192.168.1.20  ,apache端口80,tomcat端口8080 主机B tomcatB,ip:192.168.1.21,端口80 主机C tomcatC,ip:192.168.1.22,端口80 五.配置apache. 将下载的mod_jk(名字假如:mod_jk-