简述
由于开发是单机项目,但是到了配置负载均衡的集群中就发生了问题,使用账号登录后又跳回主页面。
我分析了原因是负载均衡配置的跳转是每次访问都会切换服务,所以在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(