Nginx+Tomcat+Memcached实现会话保持(MSM)

Nginx+Tomcat+Memcached实现会话保持(MSM)

1240

会话保持的三种方式

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

一、架构图

1240

系统环境

所有服务器全部采用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已经保持不变
1240
1240

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101499.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数据分析——多重共线性检验

    数据分析——多重共线性检验在做线性回归的时候,一般分为以下几个步骤:1、画散点图,简单的查看是否存在线性关系(3D以下)2、线性模型跑一遍试试效果3、其中需要查看以下几个指标:3.1正太分布检验3.1多重共线性3.2变量显著性3.4拟合效果4、解释变量上面一篇文章了解了如何利用t检验进行变量的显著性检验,下面着重学习如何进行多重共线性的检验一、辅助…

    2022年5月18日
    44
  • android armeabi armeabi-v7a(v7a和x86)

    了解起因昨天师傅问,你知道这俩个是什么么?有什么作用么?(如下图所示)现在还记得我那一脸蒙比的样子,诺诺的回答不晓得。师傅说这个是为了兼容一些手机,(此处省略滔滔不绝若干。。。)。听的我更加蒙比了,之前只是知道要把.so库扔进去,但是为什么扔,就不懂了,何谈我怎会知道那目录?(PS:还是自己差太多了。。。)好尴尬。。。查询前期准备首先按照四个部分来查询,分别如下:一.lib…

    2022年4月13日
    131
  • android开发案例「建议收藏」

    android开发案例「建议收藏」20多个可以提高你安卓开发技能的开源app学习的最佳方式就是阅读,对程序员来说也是如此。如果你想成为一个更优秀的程序员,你必须阅读更多的代码,就是这么简单。书籍,博客,论坛在某种程度上都是有益的,但是没有什么能替代功能完善、代码详细的开源项目。整个app的所有相关资源都直接呈现在你面前。AndroidTheme.AppCompat中,你应该熟悉的颜色属性创建一个Android工程

    2022年6月16日
    29
  • UltraEdit正则表达式替换空行

    UltraEdit正则表达式替换空行前提是,使用unix正则表达式,替换1、使用正规的正则表示式来提换,表达式为:^[\t]*\r\n2、如果第一种方式无法实现,直接在文本中复制空行,然后在替换时使用下面的正则表达式:^复制的内容

    2022年5月13日
    44
  • 优先队列(堆)priority queue

    优先队列(堆)priority queue优先队列(堆)priorityqueue完全二叉树:除了最底层都被元素填满堆序性:除根节点,最小堆每个节点父亲的Key小于等于该节点的Key,最大堆反之优先队列的申明structHeapStruct;typedefstructHeapStruct*PriorityQueue;PriorityQueueInitialize(intMaxElements);void…

    2022年7月16日
    16
  • 什么是publickeytoken及publickeytoken的作用

    什么是publickeytoken及publickeytoken的作用什么是publickeytoken及publickeytoken的作用dll的publickeytoken的作用。

    2022年7月1日
    22

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号