《Spring+redis实现session共享》要点:
本文介绍了Spring+redis实现session共享,希望对您有用。如果有疑问,可以联系我们。
再写之前呢,我要先补充一下基础知识讲一下原理,大家都知道session是存储在服务端,cookie是存在于客户端.session最常见的应用就是用户登录之后,存储用户的登录信息,之后用户再进行其他操作的时候判断一下session里是否有当前用户的信息,如果有就不必要登录了否则要跳转登录页面重新登录.
介绍完上面的应用场景,下面我们就来说一下实际应用中关于session遇到的问题.给大家举个栗子:
1、大家都知道阿里双11每秒的拜访量是超级多的,应该是全球最高的并发量了
2、百度、谷歌全球同时搜索,也会很快的显示出结果
要实现高并发,快速响应等效果,单单一台服务器是不行的,这就必要多台服务器,例如:A-Z,
每当一次访问过来的时候,通过负载均衡服务器(例如:Ngnix)把哀求分配到单一的服务器.而我们知道session是存储于服务端的,我们现在有多个服务端,这就势必造成了我一次登录的session信息只保存在一台服务器,我下一次访问不一定访问的是同一台服务器,这就造成了影响.这就需要我们把session的信息共享或者叫复制到其他的每一台服务器上,而如果服务器量庞大,着重复制操作很频繁而且还造成服务器资源浪费.为了解决这个问题,思路是:把所有的session信息都保存到redis数据库,然后取值的时候也是从redis里取.这样就很好的解决了上述问题.
通过下面这个图可以更好的理解通过redis实现session共享机制.
上面介绍完了配景,原理.下面我来通过代码来实现Spring+redis+session共享的功能.
1、必需jar包
spring-data-redis-1.3.4.RELEASE.jar
直接百度下载即可,或者在maven里配置自动下载.maven里我就不写了,占地方.(*^__^*)
2、配置web.xml,就是增加一个过滤器如下图.
3、配置spring,applicationContext.xml配置
这里说明一下,直接用我图中注释的spring自带的class即可,我的是本身重写了.
4、配置redis连接池
这里就不写了,相信大家都会滴,我再后期还会写相关的文章.
5、保留和读取session
我这里用的是struts2+spring框架,大家可以根据本身的实际来做,记住一点:
你原来是怎么保留session的,现在还是一个写法!只不过通过框架可以把session给保留到redis数据库中.
6、查看redis中的session
我这里使用的redis的客户端工具,出现下面spring的文件夹说明缓存成功.
至此、通过spring+redis实现session共享完成.喜欢的朋友们,欢迎关注一下
后面我会分享一下把省市区信息缓存到redis数据库中.
后续内容持续更新,如果你也在学习技术,或者你想要成为全栈工程师,可以关注一下下哈.不定期更新java、框架、centos7等内容,让你从代码、框架、linux、人工智能做一个全面了解.O(∩_∩)O
因为每天只能发送一篇文章,所以很多介绍必要后期继续推送,后期的主要介绍的是:java实现人脸登录例子、mongo数据库,spring集成redis、mongo、elasticsearch等等,喜欢的朋友可以关注我噢.
《Spring+redis实现session共享》是否对您有启发,欢迎查看更多与《Spring+redis实现session共享》相关教程,学精学透。维易PHP学院为您提供精彩教程。
转载请注明本页网址:
http://www.vephp.com/jiaocheng/9599.html