简述

由于开发是单机项目,但是到了配置负载均衡的集群中就发生了问题,使用账号登录后又跳回主页面。

我分析了原因是负载均衡配置的跳转是每次访问都会切换服务,所以在A机器登录后,再次访问B机器找不到有登录状态的session,而我的过滤器里面配置了不登录就会跳到首页,所以在B机器上给跳回了首页,这样就会一直登陆失败。

解决办法就是配置session共享,看了大多数的session共享都是用的Redis做的,但是本着不增加项目架构复杂度的想法,便使用了本身的项目数据库–oracle。

使用了spring提供的session共享方案,spring-session。

spring-session的Github地址:https://github.com/spring-projects/spring-session

数据库表

使用JDBC做session共享需要在对应库中增加表,里面包含了各种库的对应的表信息,可参考: https://github.com/spring-projects/spring-session/tree/master/spring-session-jdbc/src/main/resources/org/springframework/session/jdbc

这里是2.x版本的sql,如果是1.x版本是没有PRIMARY_ID字段的,要在下面maven依赖中选择对应的版本,不然运行报错。

CREATE TABLE SPRING_SESSION (

PRIMARY_ID CHAR(36) NOT NULL,

SESSION_ID CHAR(36) NOT NULL,

CREATION_TIME NUMBER(19,0) NOT NULL,

LAST_ACCESS_TIME NUMBER(19,0) NOT NULL,

MAX_INACTIVE_INTERVAL NUMBER(10,0) NOT NULL,

EXPIRY_TIME NUMBER(19,0) NOT NULL,

PRINCIPAL_NAME VARCHAR2(100 CHAR),

CONSTRAINT SPRING_SESSION_PK PRIMARY KEY (PRIMARY_ID)

);

CREATE UNIQUE INDEX SPRING_SESSION_IX1 ON SPRING_SESSION (SESSION_ID);

CREATE INDEX SPRING_SESSION_IX2 ON SPRING_SESSION (EXPIRY_TIME);

CREATE INDEX SPRING_SESSION_IX3 ON SPRING_SESSION (PRINCIPAL_NAME);

CREATE TABLE SPRING_SESSION_ATTRIBUTES (

SESSION_PRIMARY_ID CHAR(36) NOT NULL,

ATTRIBUTE_NAME VARCHAR2(200 CHAR) NOT NULL,

ATTRIBUTE_BYTES BLOB NOT NULL,

CONSTRAINT SPRING_SESSION_ATTRIBUTES_PK PRIMARY KEY (SESSION_PRIMARY_ID, ATTRIBUTE_NAME),

CONSTRAINT SPRING_SESSION_ATTRIBUTES_FK FOREIGN KEY (SESSION_PRIMARY_ID) REFERENCES SPRING_SESSION(PRIMARY_ID) ON DELETE CASCADE

);

Maven依赖

这里对应的找到2.x版本的依赖,如果没有maven,要引入如下jar:spring-jdbc、spring-session-core、spring-context

org.springframework.sessiongroupId>

spring-session-jdbcartifactId>

2.0.2.RELEASEversion>

dependency>

application.xml配置

bean>

class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

bean>

web.xml

spring session通过自定义一个filter,通过filter职责链将用自己定义的request替换httpservletrequest,从而使用自己httpsession。配置一下Filter,把他放在最前面,使其优先执行

springSessionRepositoryFilterfilter-name>

org.springframework.web.filter.DelegatingFilterProxyfilter-class>

filter>

springSessionRepositoryFilterfilter-name>

/*url-pattern>

filter-mapping>

总结

整和共享session步骤:增加数据库表,添加依赖,配置spring的xml,增加过滤器让request获取spring-session-jdbc中的session。

整合之后,可以登录到项目中,并在数据库的SPRING_SESSION、SPRING_SESSION_ATTRIBUTES表中看到相应的信息,而session存活时间也与原来相同,不影响其他逻辑。

参考

官方文档

XML配置spring session jdbc实现session共享

oracle不同session共享变量,SpringMVC使用oracle配置session共享相关推荐

  1. oracle数据库配置失败,oracle11g – Oracle 11G XE安装错误:数据库配置失败

    在 linuxMint上安装后运行oracle配置时: /etc/init.d/oracle-xe configure 指定以下错误: sudo /etc/init.d/oracle-xe confi ...

  2. Linux平台 Oracle 18c RAC安装Part2:GI配置

    三.GI(Grid Infrastructure)安装 3.1 解压GI的安装包 3.2 安装配置Xmanager软件 3.3 共享存储LUN的赋权 3.4 使用Xmanager图形化界面配置GI 3 ...

  3. 查询oracle数据库adg的模式,Oracle11g ADG配置

    一:注意事项 1: 目录不同 db_file_name_convert=('/u01/app/oracle/oradata/orcl/','/u01/app/oracle/oradata/oradu/ ...

  4. Linux平台 Oracle 18c RAC安装Part3:DB配置

    四.DB(Database)配置 4.1 解压DB的安装包 4.2 DB软件配置 4.3 ASMCA创建磁盘组 4.4 DBCA建库 4.5 验证crsctl的状态 Linux平台 Oracle 18 ...

  5. oracle包如何进入编辑,修改 Oracle 的process和Session

    1.process 和session的概念: process:这个参数限制了能够连接到SGA的操作系统进程数(或者是Windows 系统中的线程数),这个总数必须足够大,从而能够适用于后台进程与所有的 ...

  6. oracle开启未活动连接清理,Oracle inactive session的清理

    STATUS ACTIVE - Session currently executing SQL INACTIVE KILLED - Session marked to be killed CACHED ...

  7. 【安装篇】- 基于 VMWARE Oracle Linux7.9 安装 Oracle19c RAC 详细配置方案

    作者 | yanwei 来源 | 墨天轮 https://www.modb.pro/db/95684 大家好,我是 JiekeXu,很高兴又和大家见面了,今天和大家一起来看看 Linux7.9 安装 ...

  8. SSM框架整合(Spring+SpringMVC+MyBatis+Oracle)

    1.开发环境搭建以及创建Maven Web项目 参看之前的博文:http://www.cnblogs.com/cainiaomahua/p/6306476.html 2.SSM整合 这次整合有2个配置 ...

  9. Oracle 19C+13.5 EMCC部署和配置

    Oracle 19C+13.5EMCC 部署和配置 一:Oracle 13.5EMCC下载 二:Oracle 19C+13.5EMCC部署 三:Oracle 19C+13.5EMCC常见组件 四:Or ...

最新文章

  1. 用户自定义协议client/server代码示例
  2. spark1.4加载mysql数据 创建Dataframe及join操作连接方法问题
  3. 每日算法练习之李白喝酒问题
  4. [OSDI 16] Wukong : 基于RDMA的高并发、快速的分布式RDF Graph Query系统
  5. b+树时间复杂度_阿里面试,问了B+树,这个回答让我通过了
  6. datatable 创建列赋值_Datatable 添加新列并赋值
  7. leetcode54. 螺旋矩阵(详解)
  8. 微信内部浏览器私有接口 - WeixinJSBridge介绍
  9. vue中根据搜索内容跳转到页面指定位置
  10. 解决 clipboard.js 在ios中失效的问题
  11. [转]解决xampp无法启动apache的问题
  12. 不能bostype没有元数据异常_手把手教你用Python画个箱形图,找出“脏数据”
  13. Python中的计数(词频)
  14. ISO /TS 22163:2017轨道交通行业质量管理体系简介及相关标准资料
  15. Java的第20年:Java和我的故事
  16. C#软件注册与注册机
  17. 项目管理的五大过程组及十大知识领域
  18. 【SSL】1653数字游戏
  19. winform怎么实现七天签到_怎么管理多个微信群?怎么提高微信群管理效率?
  20. python3数据处理(一)-- 解析XML,Excle文件

热门文章

  1. 数据库的完整性和安全性
  2. 严蔚敏数据结构:链表实现一元多项式相加
  3. mysql 集群架构_mysql企业常用集群架构
  4. 局域网网络风暴检测工具_【思唯网络学院】从原理到配置,最全的VLAN说明就在这了!...
  5. sql server 2008 r2卸载重装_免费下载:Intouch软件、Windows操作系统、SQL数据库,VB6.0、C#...
  6. 集合添加元素python_Python 集合(Set)
  7. 【Python基础入门系列】第09天:Python tuple
  8. 【机器学习】opencv-视频中的人脸检测
  9. java后期发展方向_Java程序员的4个职业发展方向,该如何把握黄金5年?
  10. JS_11正则表达式和字符串方法