如何利用redis对tomcat集群的session共享的缓存啊?谁可以指点一下吗,给个案例? ++

如何利用redis对tomcat集群的session共享的缓存啊?谁可以指点一下吗,给个案例? ++,第1张

redis服务器与tomcat服务器是独立的,所以tomcat集群本身就支持共享redis服务器的资源。

所以只要在后台控制session的存储都在redis上操作便可以实现tomcat集群共享session了。

redis存储是key/value的形式,所以key可以采用sessionid(可以自己定义),value存储你想要共享的内容,比如说session里的userid信息。而key可以保存在cookie中。之后后台服务器每次需要获取共享信息,就用cookie中的key去redis中获取value就可以了。

情况一:用户1,2进入系统时候,被nginx同时分配到了服务器8082。此时用户1想对用户2发送一信息,此请求又被分配到了服务器8083。那么服务器8083向8082发出请求,让8082来执行发送程序。

情况二:用户1,2进入系统时候,被nginx同时分配到了服务器8082及8083。此时用户1想对用户2发送一信息,此请求又被分配到了服务器8081。那么服务器8081向8082发出请求,让8082来执行发送程序。

情况三:用户1,2进入系统时候,被nginx同时分配到了服务器8083。此时用户1想对用户2发送一信息,此请求又被分配到了服务器8083。

集群跑了几天,目前没有用户反应有问题。。。应该

已解决。。。先暂时用一下这方案。。。如果用户、执行程序都在同一台服务器上直接发送就可以了,反之服务器间通讯实现发送。。。

是不是时间久了会丢失登录用户的信息之类的session数据啊,这个的问题有个简单的解决方法:找到tomcat对应的目录下,conf文件下编辑webxml,设置<session-config>

<session-config>

<session-timeout>30</session-timeout>

</session-config>

这样设置就是30分钟后session失效,时间自己改

在使用spring boot做负载均衡的时候,多个app之间的session要保持一致,这样负载到不同的app时候,在一个app登录之后,而打到另外一台服务器的时候,session丢失。

常规的解决方案都是使用:如apache使用mod_jkconf。

在开发spring boot app的时候可以借助 spring session 和redis,用外置的redis来存储session的状态。

直接上代码,我这边直接默认你使用spring boot,如果你是普通的spring web项目,请参照 githubcom/spring-projects/spring-session ,在spring boot配置更简单

1、增加repository到pomxml

<repository>

<id>spring-milestone</id>

<url>repospringio/libs-milestone</url>

</repository>

2、增加相关依赖

<dependency>

<groupId>orgspringframeworkboot</groupId>

<artifactId>spring-boot-starter-redis</artifactId>

</dependency>

<dependency>

<groupId>orgspringframeworksession</groupId>

<artifactId>spring-session-data-redis</artifactId>

<version>100RC1</version>

<type>pom</type>

</dependency>

3、RedisSessionConfigjava

package comwiselybase;

import orgspringframeworkcontextannotationConfiguration;

import orgspringframeworksessiondataredisconfigannotationwebhttpEnableRedisHttpSession;

@Configuration

@EnableRedisHttpSession

public class RedisSessionConfig {

}

4、相关配置修改

在applicationproperties修改redis配置信息(请自行安装redis),请根据实际修改。如:

springredishost=1921681103

5、所有实体类实现Serializable接口

public class SysResource implements Serializable

6、查看效果

这时候登录系统在不同的app之间跳转的时候,session都是一致了,redis上可以看到:

7、总结

使用这些代码之后 ,无论你使用nginx或者apache,都无须在关心多个app之间的session一致的问题了。

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » 如何利用redis对tomcat集群的session共享的缓存啊?谁可以指点一下吗,给个案例? ++

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情