如何利用redis对tomcat集群的session共享的缓存啊?谁可以指点一下吗,给个案例? ++
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一致的问题了。
0条评论