使用Memcached做session server实现会话保持

Crq
Crq
Crq
419
文章
0
评论
2024年8月28日07:32:42
评论
10 2261字阅读7分32秒

会话保持的三种方式

Session sticky会话绑定:通过在前端调度器的配置中实现统一session发送至同一后发端服务器

Session cluster会话集群:通过配置Tomcat保持所有Tomcat的session的信息一致。

Session server 会话服务:将所有的session交给专门的session服务管理。

这里讲解第三种,使用Memcached做session server

一、架构图

系统环境

所有服务器全部采用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
    #
                                            # 定义主机组
        BalancerMember  ajp://172.18.68.21:8009 route=tomcatA
        BalancerMember  ajp://172.18.68.22:8009 route=tomcatB
        ProxySet lbmethod=byrequests
    #
                                                          # 创建虚拟主机
                ServerName www.baidu.com
                ProxyVia On
                ProxyRequests Off
                ProxyPreserveHost On
                proxyvia on
                        Require all granted
                ProxyPass / balancer://tomcatservers/                   # 设定所有调度至后端
                ProxyPassReverse / balancer://tomcatservers/            # 设定所有调度至后端
                                                            # centos7默认拒绝,所以要允许
                        Require all granted
                                            # apache的管理页面
                        SetHandler balancer-manager
                        ProxyPass !                                     # 匹配到apache的管理页面不代理
                        Require all granted                             # 设定允许
    #
    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标签内配置以下内容
                  # 黄色标记部分为流式化管理工具,如果使用其他流式化工具,更改这两个名即可

下载所依赖的软件包

将文章最开头提到的所有.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
添加如下内容:

启动服务

systemctl start tomcat
四、Memcached配置

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

yum install memcached
systemctl start memcached
五、测试

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

weinxin
我的微信
这是我的微信扫一扫
Crq
  • 本文由 发表于 2024年8月28日07:32:42
  • 转载请注明:https://www.cncrq.com/10485.html
教你在 Arch Linux 中设置日语环境 Linux教程

教你在 Arch Linux 中设置日语环境

在本教程中,我们将讨论如何在 Arch Linux 中设置日语环境。在其他类 Unix 操作系统中,设置日文布局并不是什么大不了的事情。你可以从设置中轻松选择日文键盘布局。然而,在 Arch Linu...
使用 Vundle 管理 Vim 插件 Linux教程

使用 Vundle 管理 Vim 插件

毋庸置疑,Vim 是一款强大的文本文件处理的通用工具,能够管理系统配置文件和编写代码。通过插件,Vim 可以被拓展出不同层次的功能。通常,所有的插件和附属的配置文件都会存放在 ~/.vim 目录中。由...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: