阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Apache+Tomcat+Memcached实现会话保持

410次阅读
没有评论

共计 3910 个字符,预计需要花费 10 分钟才能阅读完成。

Apache+Tomcat+Memcached 实现会话保持

会话保持的三种方式

  • Session sticky 会话绑定:通过在前端调度器的配置中实现统一 session 发送至同一后发端服务器
  • Session cluster 会话集群:通过配置 Tomcat 保持所有 Tomcat 的 session 的信息一致。
  • Session server 会话服务:将所有的 session 交给专门的 session 服务管理。
    这里讲解第三种,使用 Memcached 做 session server

一、架构图

Apache+Tomcat+Memcached 实现会话保持

系统环境

所有服务器全部采用 CentOS7.3

所需要的软件包

以下文件都要放置在 tomcat 服务器主机上的类库目录中

rpm -ql tomcat-lib                  #   
/usr/share/java/tomcat/             # yum 安装默认在此目录
/usr/local/tomcat/lib               # 在官网 rpm 安装的默认在此目录了
memcached-session-manager-1.8.3.jar
        http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager/1.8.3/
memcached-session-manager-tc7-1.8.3.jar
        http://repo1.maven.org/maven2/de/javakaffee/msm/memcached-session-manager-tc7/1.8.3/
spymemcached-2.11.1.jar
        http://repo1.maven.org/maven2/net/spy/spymemcached/2.11.1/
javolution-5.4.3.1.jar      
        http://memcached-session-manager.googlecode.com/svn/maven/javolution/javolution/5.4.3.1/
msm-javolution-serializer-1.8.3.jar
        http://repo1.maven.org/maven2/de/javakaffee/msm/msm-javolution-serializer/1.8.3/

二、Apache 详细配置

  • 安装 httpd

    yum install httpd
  • 创建配置文件
    /etc/httpd/conf.d下新建一个配置文件

    shell > vim /etc/httpd/conf.d/ajp-tomcat.conf
    #
    <proxy balancer://tomcatservers>                                        # 定义主机组
        BalancerMember  ajp://172.18.68.21:8009 route=tomcatA
        BalancerMember  ajp://172.18.68.22:8009 route=tomcatB
        ProxySet lbmethod=byrequests
    </proxy>
    #
    <virtualhost *:80>                                                      # 创建虚拟主机
                ServerName www.baidu.com
                ProxyVia On
                ProxyRequests Off
                ProxyPreserveHost On
                proxyvia on
                <Proxy *>
                        Require all granted
                </Proxy>
                ProxyPass / balancer://tomcatservers/                   # 设定所有调度至后端
                ProxyPassReverse / balancer://tomcatservers/            # 设定所有调度至后端
                <Location />                                            # centos7 默认拒绝,所以要允许
                        Require all granted
                </Location>
                <Location /balancer-manager>                            # apache 的管理页面
                        SetHandler balancer-manager
                        ProxyPass !                                     # 匹配到 apache 的管理页面不代理
                        Require all granted                             # 设定允许
                </Location>
    </virtualhost>
    #
    shell > systemctl start httpd

三、Tomcat 的配置

两台 tocat 的配置大同小异,配置文件基本都相同,仅是后面创建的两个测试页面不同而已。

  • 安装 Tomcat

    yum install tomcat tomcat-admin-webapps  tomcat-webapps
  • 修改配置文件
    在 /etc/tomcat/ 下有个 server.xml 文件,打开这个文件后在 host 标签内添加或者修改如下配置。

    vim /etc/tomcat/server.xml
    在 host 标签内配置以下内容
    <Context path="/myapp" docBase="myapp"  reloadable="true">
      <Manager className="de.javakaffee.web.msm.MemcachedBackupSessionManager"
           memcachedNodes="n1:172.18.68.31:11211,n2:172.18.68.32:11211"  
    #n1:IP:prot 为后端两个 memcached 地址
    #
    failoverNodes="n2"        # 设定 n2 备用。所以 n1 就是主
    requestUriIgnorePattern=".*\.(ico|png|gif|jpg|css|js)$"             # 匹配到这些结尾的文件不考虑 cookie
    transcoderFactoryClass="de.javakaffee.web.msm.serializer.javolution.JavolutionTranscoderFactory"
    />
    </Context>                  # 黄色标记部分为流式化管理工具,如果使用其他流式化工具,更改这两个名即可
  • 下载所依赖的软件包
    将文章最开头提到的所有.jar 文件结尾的文件软布放置在 tomcat 服务器主机上的类库目录中

    rpm -ql tomcat-lib                  # 通过此命令查看.jar 文件存放的目录,就是类库文件的目录
    /usr/share/java/tomcat/             # yum 安装的 tomcat 类库路径
    /usr/local/tomcat/lib               # 在官网 rpm 安装的 tomcat 类库路径
  • 添加测试页面
    下面两个测试页面各不相相同,所以要在各自的目录下分别创建。
    在 tomcatA 中添加测试页面

    shell > mkdir -pv /usr/local/tomcat/webapps/test/WEB-INF/{classes,lib}
    shell > vim /usr/local/tomcat/webapps/test/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>

    在 tomcatB 中添加测试页面

    shell > mkdir -pv /usr/local/tomcat/webapps/test/WEB-INF/{classes,lib}
    shell > vim /usr/local/tomcat/webapps/test/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> 
  • 启动服务

    systemctl start tomcat

四、Memcached 配置

Mechached 基本没有什么配置的,安装上启动服务即可.

yum install memcached
systemctl start memcached

五、测试

使用浏览器访问 http://172.18.68.11, 然后多次刷新,只要 SessionID 这一栏的数值不变就说明 session 已经保持不变
Apache+Tomcat+Memcached 实现会话保持
Apache+Tomcat+Memcached 实现会话保持

在 Ubuntu 17.10 上安装 LAMP(Apache,MariaDB,PHP7.1)http://www.linuxidc.com/Linux/2017-10/148065.htm

Ubuntu 17.10 上使用 Apache+MariaDB+PHP7.1 安装 WordPress  http://www.linuxidc.com/Linux/2017-10/148066.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-11/148718.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-21发表,共计3910字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
7972922
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

星哥带你玩飞牛NAS-16:不再错过公众号更新,飞牛NAS搭建RSS

  星哥带你玩飞牛 NAS-16:不再错过公众号更新,飞牛 NAS 搭建 RSS 对于经常关注多个微...
把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地

把小米云笔记搬回家:飞牛 NAS 一键部署,小米云笔记自动同步到本地 大家好,我是星哥,今天教大家在飞牛 NA...
还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手! 前言 对于个人开发者、建站新手或是想搭建测试站点的从业者...
星哥带你玩飞牛NAS-2:飞牛配置RAID磁盘阵列

星哥带你玩飞牛NAS-2:飞牛配置RAID磁盘阵列

星哥带你玩飞牛 NAS-2:飞牛配置 RAID 磁盘阵列 前言 大家好,我是星哥之前星哥写了《星哥带你玩飞牛 ...
安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装Black群晖DSM7.2系统安装教程(在Vmware虚拟机中、实体机均可)!

安装 Black 群晖 DSM7.2 系统安装教程(在 Vmware 虚拟机中、实体机均可)! 前言 大家好,...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛NAS硬件03:五盘位+N5105+双网口的成品NAS值得入手吗

星哥带你玩飞牛 NAS 硬件 03:五盘位 +N5105+ 双网口的成品 NAS 值得入手吗 前言 大家好,我...
颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

  颠覆 AI 开发效率!开源工具一站式管控 30+ 大模型 ApiKey,秘钥付费 + 负载均衡全...
还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手! 前言 对于个人开发者、建站新手或是想搭建测试站点的从业者...
星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛NAS硬件02:某鱼6张左右就可拿下5盘位的飞牛圣体NAS

星哥带你玩飞牛 NAS 硬件 02:某鱼 6 张左右就可拿下 5 盘位的飞牛圣体 NAS 前言 大家好,我是星...
星哥带你玩飞牛NAS-11:咪咕视频订阅部署全攻略

星哥带你玩飞牛NAS-11:咪咕视频订阅部署全攻略

星哥带你玩飞牛 NAS-11:咪咕视频订阅部署全攻略 前言 在家庭影音系统里,NAS 不仅是存储中心,更是内容...