linux中redis做session共享,Spring+redis实现session共享

再写之前呢,我要先补充一下基础知识讲一下原理,大家都知道session是存储在服务端,cookie是存在于客户端。session最常见的应用就是用户登录之后,存储用户的登录信息,之后用户再进行其他操作的时候判断一下session里是否有当前用户的信息,如果有就不需要登录了否则要跳转登录页面重新登录。

介绍完上面的应用场景,下面我们就来说一下实际应用中关于session遇到的问题。给大家举个栗子:

1、大家都知道阿里双11每秒的访问量是超级多的,应该是全球最高的并发量了

2、百度、谷歌全球同时搜索,也会很快的显示出结果

要实现高并发,快速响应等效果,单单一台服务器是不行的,这就需要多台服务器,例如:A-Z,

每当一次访问过来的时候,通过负载均衡服务器(例如:Ngnix)把请求分配到单一的服务器。而我们知道session是存储于服务端的,我们现在有多个服务端,这就势必造成了我一次登录的session信息只保存在一台服务器,我下一次访问不一定访问的是同一台服务器,这就造成了影响。这就需要我们把session的信息共享或者叫复制到其他的每一台服务器上,而如果服务器量庞大,着重复制操作很频繁而且还造成服务器资源浪费。为了解决这个问题,思路是:把所有的session信息都保存到redis数据库,然后取值的时候也是从redis里取。这样就很好的解决了上述问题。

通过下面这个图可以更好的理解通过redis实现session共享机制。

fff2db38077bc3d7c5f6ced0386331bf.png

上面介绍完了背景,原理。下面我来通过代码来实现Spring+redis+session共享的功能。

1、必须jar包

spring-data-redis-1.3.4.RELEASE.jar

直接百度下载即可,或者在maven里配置自动下载。maven里我就不写了,占地方。(*^__^*)

2、配置web.xml,就是增加一个过滤器如下图。

303526d0e8909ad04c81613b3baf879f.png

3、配置spring,applicationContext.xml配置

bfc01d777cc223bdc98f84a8e5d6abb9.png

这里说明一下,直接用我图中注释的spring自带的class即可,我的是自己重写了。

4、配置redis连接池

这里就不写了,相信大家都会滴,我再后期还会写相关的文章。

5、保存和读取session

1a87afcc76e1e18aa5e60f9d4bd37d4f.png

我这里用的是struts2+spring框架,大家可以根据自己的实际来做,记住一点:

你原来是怎么保存session的,现在还是一个写法!只不过通过框架可以把session给保存到redis数据库中。

6、查看redis中的session

我这里使用的redis的客户端工具,出现下面spring的文件夹说明缓存成功。

7df1ab49fc34a0d46955b30a99f29c96.png

至此、通过spring+redis实现session共享完成。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值