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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Bootstrap使用及环境搭建详解

    Bootstrap使用及环境搭建详解Bootstrap官网官网:https://getbootstrap.com/中文网:http://www.bootcss.com/为什么要使用Bootstrap?首先,观察Bootstrap文件树(下图)不难发现,文件都是我们常见的一些css、js文件。Bootstrap为我们写好测试了各种兼容、疑难问题,并构建了一套非常优秀成熟的响应式类,并及时提供了移动端优先的响应式系统,我们只需…

    2025年7月13日
    2
  • Ubuntu卸载软件_ubuntu软件卸载

    Ubuntu卸载软件_ubuntu软件卸载之前安装teamviewer的时候,强制进行安装,结果安装失败,并且,之后无论运行任何apt-getintsll命令都会报错:解决办法是:直接将这个软件删除掉就行了,运行以下命令:sudoapt-getremove–purgeteamviewer:i386

    2022年9月28日
    2
  • 怎么安装pycharm及环境变量配置_pycharm配置python环境

    怎么安装pycharm及环境变量配置_pycharm配置python环境pycharm安装以及其环境的配置说明此次我们使用win10系统安装pycharm的64位社区版,并且对Anaconda3中自带的Python3进行环境的配置,如果您没有Anaconda3甚至是没有Python3环境,可以参考Anaconda3安装教程及说明,如果您的pip源未更改,这里推荐您改为使用国内的pip源,这样可以更快的下载组件,方法见修改pip源至国内镜像网站。教程从开始菜单中找到你的AnacondaPrompt并打开…

    2022年8月26日
    7
  • 编程语言中,取余和取模的区别

    编程语言中,取余和取模的区别编程语言中,取余和取模的区别

    2022年4月24日
    45
  • mac系统安装win10双系统「建议收藏」

    mac系统安装win10双系统「建议收藏」一个月前,为了在家里学习单片机,在macbookair系统基础上,安装了win10,搞了一个双系统。在安装之前,看了很多资料,基本上提到两点,一个是准备win10镜像,一个是准备win10安装启动程序,而且至少需要一个U盘,有的也说需要两个,一个用来装win10镜像,一个用来装win10启动程序。最后动手安装的时候,一个U盘也没有使用,直接把win10镜像下载到mac系统中,然后启动mac上的磁盘管理工具,按照提示,傻瓜式的进行下一步。有两个地方需要我们手动设…

    2022年9月27日
    1
  • beanshell脚本语法_shell脚本实战pdf免费

    beanshell脚本语法_shell脚本实战pdf免费本文内容是BeanShell入门教程的中文化主要包含了以下内容1.快速入门2.基本语法3.脚本方法4.脚本对象5.范围值快速入门1.下载和运行BeanShell我们可以在http://www.beanshell.org上下载到BeanShell的最新版本,而且可以在图形化桌面模式或者命令行模式下运行。如果你只是想下载下来玩玩看,那么双击JAR文件,运行桌面版的就可以了。但是,或许你更想以后长期使用…

    2025年6月18日
    2

发表回复

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

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