《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.snjht.com/jiaocheng/9599.html