会话保持的三种方式

  • 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
#
<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已经保持不变



Nginx+Tomcat+Memcached实现会话保持的更多相关文章

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

    会话保持的三种方式 Session sticky会话绑定:通过在前端调度器的配置中实现统一session发送至同一后发端服务器 Session cluster会话集群:通过配置Tomcat保持所有To ...

  2. Nginx+Tomcat+memcached高可用会话保持

    Nginx+Tomcat+memcached高可用会话保持 文章来源dyc2005   一.概述 之前文章已经描述了企业高可用负载相关的架构及实现,其中常用的nginx或haproxy,LVS结合ke ...

  3. Nginx+Tomcat+Memcached负载均衡集群服务搭建

    操作系统:CentOS6.5  本文档主要讲解,如何在CentOS6.5下搭建Nginx+Tomcat+Memcached负载均衡集群服务器,Nginx负责负载均衡,Tomcat负责实际服务,Memc ...

  4. Nginx+Tomcat+Memcached实现session共享

    实验环境: server1:nginx tomcat memcached server2:tomcat memcached Session是指一个终端用户与交互系统进行通信的时间间隔,通常指从注册进入 ...

  5. 【转】Nginx+Tomcat+Memcached集群Session共享

    cookie是怎样工作的? 例 如,我们创建了一个名字为login的Cookie来包含访问者的信息,创建Cookie时,服务器端的Header如下面所示,这里假设访问者的注册名 是“Michael J ...

  6. Nginx+Tomcat+Memcached 集群

    写过一篇 Apache Httpd+Tomcat 的集群, 现在来看看Nginx+Tomcat+Memcached是怎么集群的. 先看看用的版本和工具: Nginx: nginx-1.8.1 Tomc ...

  7. session服务器Nginx+Tomcat+Memcached集群Session共享

    cookie是怎样工作的? 例如,我们创立了一个名字为login的Cookie来包含访问者的信息,创立Cookie时,服务器端的Header如下面所示,这里假设访问者的注册名是“Michael Jor ...

  8. Nginx+Tomcat+MemCached 集群配置手册

    系统实施文档 Nginx+Tomcat+MemCached 集群配置手册 目    录 第1章   概述 1.1   目标 互联网的快速发展带来了互联网系统的高负载和高可用性, 这要求我们在设计系统架 ...

  9. Nginx+Tomcat+Memcached 实现集群部署时Session共享

    Nginx+Tomcat+Memcached 实现集群部署时Session共享 一.简介 我们系统经常要保存用户登录信息,有Cookie和Session机制,Cookie客户端保存用户信息,Sessi ...

随机推荐

  1. 实现mysql在windows server 2008下自动备份

    环境:MySQL   安装位置:D:\MySQL论坛数据库名称为:Db_Test数据库备份目的地:D:\db_bak\ 1.首先新建一个bat文件 rem ********************** ...

  2. WPF DataGrid显格式

    Guide to WPF DataGrid formatting using bindings Peter Huber SG, 25 Nov 2013 CPOL    4.83 (13 votes) ...

  3. js系列教程1-数组操作全解

    全栈工程师开发手册 (作者:栾鹏) 快捷链接: js系列教程1-数组操作全解 js系列教程2-对象和属性全解 js系列教程3-字符串和正则全解 js系列教程4-函数与参数全解 js系列教程5-容器和算 ...

  4. iOS之浅谈纯代码控制UIViewController视图控制器跳转界面的几种方法

    .最普通的视图控制器UIViewContoller 一个普通的视图控制器一般只有模态跳转的功能(ipad我不了解除外,这里只说iPhone),这个方法是所有视图控制器对象都可以用的,而实现这种功能,有 ...

  5. CSS3选择器在HTML5中的使用

    1,有CLASS属性的input标记 Input[class]{ } 2,class属性是sm的元素 Input[class='sm']{} 3,  凡是class=sm的元素 [class='sm' ...

  6. Vector容器构造函数

    No1 vector(); No2 vector( const vector& c ); No3 explicit vector( size_type num, const TYPE& ...

  7. SSM框架+slf4j 以Gradle实现

    环境:win10+jdk8+tomcat9+Intellij IDEA 首先,作为一个喜欢偷懒的人,管理jar之类的的事情太累,所以用了Gradle项目管理器 第一步: 新建一个gradle-web项 ...

  8. struts2类型转换相关问题

    一.类型转化错误时,如何处理? 若Action类没有实现ValidationAware接口,在类型转化错误时,struts2会继续调用action方法,将该属性值置为默认值,不报错. 若Action类 ...

  9. ArrayList 源码(基于Java1.8)

    ArrayList 源码 ArrayList 基于数组实现,也就是类对变量 Object[]系列操作,封装为常用的add,remove,indexOf, contains本质是通过 size 计数器对 ...

  10. ASP.NET中登录时记住用户名和密码(附源码下载)--ASP.NET

    必需了解的:实例需要做的是Cookie对象的创建和对Cookie对象数据的读取,通过Response对象的Cookies属性创建Cookie,通过Request对象的Cookies可以读取Cookie ...