进入swagger的接口文档页面,进行测试接口请求:
8000端口控制台输出:
然后请求8001的同一个接口:
从上面两张图可以看出虽然是同一套代码,去session里获取的同一个参数,2个端口获取的值却不同,这就是分布式中需要解决的问题:数据共享。
之前的文章有讲过用redis做分布式锁,其实这里也可以用redis解决session共享的问题。
在引入redis之前,先简单贴一下怎么在配置文件里修改session默认过期时间。从上图可以看到session默认过期时间是1800秒,也就是30分钟,如果想要延长,可以在配置文件application.yml中修改:
回归正题,要用redis解决session共享,首先需要引入依赖包:
然后还需要在配置文件中配置:
其实这里也可以设置session的过期时间,为了和上面的作对比,此处设置过期时间为2小时。
无需修改代码,重新启动2个端口,再分别请求同一个接口:
8000端口控制台输出:
8001端口控制台输出:
再看redis:
另外值得注意的是,当上面2处都配置session过期时间时,实际是以spring下的配置为准的。
以上就是Redis解决Session共享问题的方法详解的详细内容,更多关于Redis解决Session共享的资料请关注七叶笔记其它相关文章!