1. 首页
  2. IT资讯

Spring Boot一个依赖搞定 Session 共享

“u003Cpu003E优质文章,及时送达u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRcsUnd92eoboDR” img_width=”640″ img_height=”29″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E作者:江南一点雨u003Cu002Fpu003Eu003Cpu003E有的人可能会觉得题目有点夸张,其实不夸张,题目没有使用任何修辞手法!认真读完本文,你就知道说的是对的了!u003Cu002Fpu003Eu003Cpu003E在传统的单服务架构中,一般来说,只有一个服务器,那么不存在 Session 共享问题,但是在分布式u002F集群项目中,Session 共享则是一个必须面对的问题,先看一个简单的架构图:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002FRis5nqK67xmC1X” img_width=”567″ img_height=”415″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E在这样的架构中,会出现一些单服务中不存在的问题,例如u003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-2″u003E客户端u003Cu002Fiu003E发起一个请求,这个请求到达 Nginx 上之后,被 Nginx 转发到 Tomcat A 上,然后在 Tomcat A 上往 session 中保存了一份数据,下次又来一个请求,这个请求被转发到 Tomcat B 上,此时再去 Session 中获取数据,发现没有之前的数据。对于这一类问题的解决,思路很简单,就是将各个服务之间需要共享的数据,保存到一个公共的地方(主流方案就是 Redis):u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5nqW64akudJ” img_width=”810″ img_height=”392″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E当所有 Tomcat 需要往 Session 中写数据时,都往 Redis 中写,当所有 Tomcat 需要读数据时,都从 Redis 中读。这样,不同的服务就可以使用相同的 Session 数据了。u003Cu002Fpu003Eu003Cpu003E这样的方案,可以由开发者手动实现,即手动往 Redis 中存储数据,手动从 Redis 中读取数据,相当于使用一些 Redis u003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-2″u003E客户端u003Cu002Fiu003E工具来实现这样的功能,毫无疑问,手动实现工作量还是蛮大的。u003Cu002Fpu003Eu003Cpu003E一个简化的方案就是使用 Spring Session 来实现这一功能,Spring Session 就是使用 Spring 中的代理过滤器,将所有的 Session 操作拦截下来,自动的将数据 同步到 Redis 中,或者自动的从 Redis 中读取数据。u003Cu002Fpu003Eu003Cpu003E对于开发者来说,所有关于 Session 同步的操作都是透明的,开发者使用 Spring Session,一旦配置完成后,具体的用法就像使用一个普通的 Session 一样。u003Cu002Fpu003Eu003Cpu003Eu003Cu002Fpu003Eu003Ch1 toutiao-origin=”h1″u003E一、实战u003Cu002Fh1u003Eu003Ch2 toutiao-origin=”h2″u003Eu003Cstrongu003E1.1、创建工程u003Cu002Fstrongu003Eu003Cu002Fh2u003Eu003Cpu003E首先 创建一个 Spring Boot 工程,引入 Web、Spring Session 以及 Redis:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5nqqB98nf4J” img_width=”802″ img_height=”569″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E创建成功之后,pom.xml 文件如下:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5nrBALLacq” img_width=”498″ img_height=”284″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003Eu003Cstrongu003E注意:u003Cu002Fstrongu003Eu003Cu002Fpu003Eu003Cpu003E这里我使用的 Spring Boot 版本是 2.1.4 ,如果使用当前最新版 Spring Boot2.1.5 的话,除了上面这些依赖之外,需要额外添加 Spring Security 依赖(其他操作不受影响,仅仅只是多了一个依赖,当然也多了 Spring Security 的一些默认认证流程)。u003Cu002Fpu003Eu003Cpu003Eu003Cu002Fpu003Eu003Ch2 toutiao-origin=”h2″u003Eu003Cstrongu003E1.2、配置 Redisu003Cu002Fstrongu003Eu003Cu002Fh2u003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002FRis5nrKEYoTTC1″ img_width=”399″ img_height=”88″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E这里的 Redis ,我虽然配置了四行,但是考虑到端口默认就是 6379 ,database 默认就是 0,所以真正要配置的,其实就是两行。u003Cu002Fpu003Eu003Cpu003Eu003Cu002Fpu003Eu003Ch2 toutiao-origin=”h2″u003Eu003Cstrongu003E1.3、使用u003Cu002Fstrongu003Eu003Cu002Fh2u003Eu003Cpu003E配置完成后 ,就可以使用 Spring Session 了,其实就是使用普通的 HttpSession ,其他的 Session 同步到 Redis 等操作,框架已经自动帮你完成了:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5o3H3zBXaWG” img_width=”488″ img_height=”284″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E考虑到一会 Spring Boot 将以集群的方式启动 ,为了获取每一个请求到底是哪一个 Spring Boot 提供的服务,需要在每次请求时返回当前服务的端口号,因此这里我注入了 server.port 。u003Cu002Fpu003Eu003Cpu003E接下来 ,项目打包:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002FRis5o3Z6aeRiYR” img_width=”454″ img_height=”339″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E打包之后,启动项目的两个实例:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5o3f9Xaudul” img_width=”486″ img_height=”48″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E然后先访问 u003Ccodeu003Elocau003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-6″u003Elhu003Cu002Fiu003Eost:8080u002Fsetu003Cu002Fcodeu003E向u003Ccodeu003E8080u003Cu002Fcodeu003E这个服务的u003Ccodeu003ESessionu003Cu002Fcodeu003E中保存一个变量,访问完成后,数据就已经自动同步到u003Ccodeu003ERedisu003Cu002Fcodeu003E中 了 :u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp9.pstatp.comu002Flargeu002Fpgc-imageu002FRis5o3tGUuqiOe” img_width=”642″ img_height=”70″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E然后,再调用 u003Ccodeu003Elocau003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-6″u003Elhu003Cu002Fiu003Eost:8081u002Fgetu003Cu002Fcodeu003E接口,就可以获取到u003Ccodeu003E8080u003Cu002Fcodeu003E服务的u003Ccodeu003Esessionu003Cu002Fcodeu003E中的数据:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5o3zA0gyxzp” img_width=”344″ img_height=”90″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E此时关于 session 共享的配置就已经全部完成了,session 共享的效果我们已经看到了,但是每次访问都是我自己手动切换服务实例,因此,接下来我们来引入 Nginx ,实现服务实例自动切换。u003Cu002Fpu003Eu003Cpu003Eu003Cu002Fpu003Eu003Ch2 toutiao-origin=”h2″u003Eu003Cstrongu003E1.4、引入 Nginxu003Cu002Fstrongu003Eu003Cu002Fh2u003Eu003Cpu003E很简单,进入 Nginx 的安装目录的 conf 目录下(默认是在 u003Ccodeu003Eu002Fusru002Flocalu002Fnginxu002Fconfu003Cu002Fcodeu003E),编辑 nginx.conf 文件:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5oCEGrSO4ZS” img_width=”445″ img_height=”331″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E在这段配置中:u003Cu002Fpu003Eu003Cpu003E1、upstream 表示配置上游服务器u003Cu002Fpu003Eu003Cpu003E2、javaboy.org 表示服务器集群的名字,这个可以随意取名字u003Cu002Fpu003Eu003Cpu003E3、upstream 里边配置的是一个个的单独服务u003Cu002Fpu003Eu003Cpu003E4、weight 表示服务的权重,意味者将有多少比例的请求从 Nginx 上转发到该服务上u003Cu002Fpu003Eu003Cpu003E5、location 中的 proxy_pass 表示请求转发的地址, u003Ccodeu003Eu002Fu003Cu002Fcodeu003E表示拦截到所有的请求,转发转发到刚刚配置好的服务集群中u003Cu002Fpu003Eu003Cpu003E6、proxy_redirect 表示设置当发生重定向请求时,nginx 自动修正响应头数据(默认是 Tomcat 返回重定向,此时重定向的地址是 Tomcat 的地址,我们需要将之修改使之成为 Nginx 的地址)。u003Cu002Fpu003Eu003Cpu003ETips:u003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-6″u003E关注u003Cu002Fiu003Eu003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-4″u003E微信u003Cu002Fiu003Eu003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-3″u003E公众号u003Cu002Fiu003E:Java后端,每日提送技术博文。u003Cu002Fpu003Eu003Cpu003E配置完成后,将本地的 Spring Boot 打包好的 jar 上传到 Linux ,然后在 Linux 上分别启动两个 Spring Boot 实例:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5oCYDJl22ko” img_width=”543″ img_height=”48″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E其中u003Cu002Fpu003Eu003Culu003Eu003Cliu003Eu003Cpu003Enohup 表示当终端关闭时,Spring Boot 不要停止运行u003Cu002Fpu003Eu003Cu002Fliu003Eu003Cliu003Eu003Cpu003E& 表示让 Spring Boot 在后台启动u003Cu002Fpu003Eu003Cu002Fliu003Eu003Cu002Fulu003Eu003Cpu003E配置完成后,重启 Nginx:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5oCqIw7h4th” img_width=”448″ img_height=”24″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003ENginx 启动成功后,我们首先手动清除 Redis 上的数据,然后访问 u003Ccodeu003E192.168.66.128u002Fsetu003Cu002Fcodeu003E表示向u003Ccodeu003Esessionu003Cu002Fcodeu003E中保存数据,这个请求首先会到达u003Ccodeu003ENginxu003Cu002Fcodeu003E上,再由u003Ccodeu003ENginxu003Cu002Fcodeu003E转发给某一个u003Ccodeu003ESpringBootu003Cu002Fcodeu003E实例:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp1.pstatp.comu002Flargeu002Fpgc-imageu002FRis5oD4EAFMiS4″ img_width=”379″ img_height=”97″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E如上,表示端口为 u003Ccodeu003E8081u003Cu002Fcodeu003E的u003Ccodeu003ESpringBootu003Cu002Fcodeu003E处理了这个u003Ccodeu003Eu002Fsetu003Cu002Fcodeu003E请求,再访问u003Ccodeu003Eu002Fgetu003Cu002Fcodeu003E请求:u003Cu002Fpu003Eu003Cimg src=”http:u002Fu002Fp3.pstatp.comu002Flargeu002Fpgc-imageu002FRis5oDECjJnpp2″ img_width=”399″ img_height=”91″ alt=”Spring Boot一个依赖搞定 Session 共享” inline=”0″u003Eu003Cpu003E可以看到, u003Ccodeu003Eu002Fgetu003Cu002Fcodeu003E请求是被端口为 8080 的服务所处理的。u003Cu002Fpu003Eu003Cpu003Eu003Cu002Fpu003Eu003Ch1 toutiao-origin=”h1″u003E二、总结u003Cu002Fh1u003Eu003Cpu003E本文主要向大家介绍了 Spring Session 的使用,另外也涉及到一些 Nginx 的使用 ,虽然本文较长,但是实际上 Spring Session 的配置没啥。u003Cu002Fpu003Eu003Cpu003E我们写了一些代码,也做了一些配置,但是全都和 Spring Session 无关,配置是配置 Redis,代码就是普通的 HttpSession,和 Spring Session 没有任何关系!u003Cu002Fpu003Eu003Cpu003E唯一和 Spring Session 相关的,可能就是我在一开始引入了 Spring Session 的依赖吧!u003Cu002Fpu003Eu003Cpu003E如果大家没有在 SSM 架构中用过 Spring Session ,可能不太好理解我们在 Spring Boot 中使用 Spring Session 有多么方便,因为在 SSM 架构中,Spring Session 的使用要配置三个地方 ,一个是 web.xml 配置代理过滤器,然后在 Spring 容器中配置 Redis,最后再配置 Spring Session,步骤还是有些繁琐的,而 Spring Boot 中直接帮我们省去了这些繁琐的步骤!不用再去配置 Spring Session。u003Cu002Fpu003Eu003Cpu003E好了 ,本文就说到这里,有问题欢迎讨论 ,本文相关案例我已经上传到 GitHub ,大家可以自行u003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-3″u003E下载u003Cu002Fiu003E:u003Cu002Fpu003Eu003Cpu003Eu003Cstrong toutiao-origin=”span” class=”highlight-text”u003Ehttps:u002Fu002Fgithubu003Ci class=”chrome-extension-mutihighlight chrome-extension-mutihighlight-style-4″u003E.comu003Cu002Fiu003Eu002Flenveu002Fjavaboy-code-samplesu003Cu002Fstrongu003Eu003Cu002Fpu003Eu003Cp class=”pgc-end-source”u003E【END】u003Cu002Fpu003E”

原文始发于:Spring Boot一个依赖搞定 Session 共享

主题测试文章,只做测试使用。发布者:逗乐男神i,转转请注明出处:http://www.cxybcw.com/17724.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code