分布式 session

分布式 session

种 session 的时候需要注意范围,也就是 cookie.domain

比如两个域名:a.heo.com,b.heo.com。如果要共享 cookie,可以种一个更高层的公共域名,比如 heo.com。

当服务器 A (localhost:8080)登录用户,然后请求发到服务器 B(localhost:8081),那么结果请求 B 时,B 还会作出相应吗?这就需要考虑到分布式 session。

当用户在 A 登录,所以 session(用户登录信息)存在了 A 上,然后因为 B 没有用户信息,所以不认识用户,也做不出正确的响应。

在这里插入图片描述

解决方案:共享存储 ,而不是把数据放到单台服务器的内存中。

Session 共享实现Redis

如何共享存储?

  1. Redis(基于内存的 K / V 数据库)此处选择 Redis,因为用户信息读取 / 是否登录的判断极其频繁 ,Redis 基于内存,读写性能很高,简单的数据单机 (qps 5w - 10w)。
  2. MySQL
  3. 文件服务器 ceph

redis 管理工具可以使用 quickredis。

使用方法

  1. 引入 redis,能够操作 redis:
<!-- redis -->
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.6.4</version>
</dependency>
  1. 引入 spring-session 和 redis 的整合,自动将 session 存储到 redis 中:
<!-- session-data-redis -->
<!-- https://mvnrepository.com/artifact/org.springframework.session/spring-session-data-redis -->
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
<version>2.6.3</version>
</dependency>
  1. 修改 spring-session 存储配置 spring.session.store-type。默认是 none,表示存储在单台服务器 。store-type: redis,表示从 redis 读写 session。
spring:application:name: match-matesession:timeout: 86400store-type: redisredis:port: 6379host: localhostdatabase: 0
  1. 测试结果

为了测试结果,我们可以用不同的端口启动我们的后端项目。一,idea在8080端口启动。二,打包后再8081端口启动。

image.png

8080端口:

image.png

8081端口:

image.png

成功携带8080端口登录获得的用户信息(session),来请求响应8081端口的接口。

查看 redis 0号库 成功存储 session。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/421910.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法优化:LeetCode第122场双周赛解题策略与技巧

接下来会以刷常规题为主 &#xff0c;周赛的难题想要独立做出来还是有一定难度的&#xff0c;需要消耗大量时间 比赛地址 3011. 判断一个数组是否可以变为有序 public class Solution {public int minimumCost(int[] nums) {if (nums.length < 3) {// 数组长度小于3时&a…

亚马逊、速卖通、虾皮、Lazada等跨境电商自养号测评的优势

作为一名跨境卖家&#xff0c;深知测评在提升产品排名、权重和销量方面的重要性。然而&#xff0c;随着测评需求的不断增长&#xff0c;寻求测评的过程中也充满了挑战。为了规避风险&#xff0c;许多大卖家开始选择自建测评团队。 下面&#xff0c;将为你详细阐述自养号的优势…

成绩等级分数段查询(python条件分支语句match...case...)

根据有效分数序列及等级差值&#xff0c;计算并打印等级相应分数区间。 (笔记模板由python脚本于2024年01月20日 23:57:32创建&#xff0c;本篇笔记适合会条件分支语句的初学者的coder翻阅) 【学习的细节是欢悦的历程】 Python 官网&#xff1a;https://www.python.org/ Free&…

Oracle1 数据库管理

Oracle的安装 一、基础表的创建 1.1 切换到scott用户 用sys 账户 登录 解锁scott账户 alter user scott account unlock;conn scott/tiger;发现并不存在scott账户&#xff0c;自己创建一个&#xff1f; 查找资料后发现&#xff0c;scott用户的脚本需要自己执行一下 C:\ap…

Java面试题50道

文章目录 1.谈谈你对Spring的理解2.Spring的常用注解有哪些3.Spring中的bean线程安全吗4.Spring中的设计模式有哪些5.Spring事务传播行为有几种6.Spring是怎么解决循环依赖的7.SpringBoot自动配置原理8.SpringBoot配置文件类型以及加载顺序9.SpringCloud的常用组件有哪些10.说一…

【JavaEE进阶】 关于⽇志框架(SLF4J)

文章目录 &#x1f333;SLF4j&#x1f332;⻔⾯模式(外观模式)&#x1f6a9;⻔⾯模式的定义&#x1f6a9;⻔⾯模式的优点 &#x1f343;关于SLF4J框架&#x1f6a9;不引⼊⽇志⻔⾯&#x1f6a9;引⼊⽇志⻔⾯ ⭕总结 &#x1f333;SLF4j SLF4J不同于其他⽇志框架,它不是⼀个真正…

ETF是什么?为什么要做ETF?做ETF的好处是什么?

现在越来越多的人都在做ETF了。那ETF到底怎么做&#xff1f;大家对股票和基金都不陌生&#xff0c;但对ETF就不太熟悉了。今天&#xff0c;咱们就对ETF做个相对全面的介绍&#xff0c;希望对大家投资有所帮助哦&#xff01;ETF具体操作详情查看&#xff0c;注意结尾惊喜福利&am…

CGLIB动态代理(AOP原理)(面试重点)

推荐先看JDK 动态代理&#xff08;Spring AOP 的原理&#xff09;&#xff08;面试重点&#xff09; JDK 动态代理与 CGLIB 动态代理的区别 JDK 动态代理有⼀个最致命的问题是其只能代理实现了接⼝的类. 有些场景下,我们的业务代码是直接实现的,并没有接⼝定义.为了解决这个问…

使用禅道进行项目管理_后台自定义功能介绍

文章目录 前言一、前置权限二、自定义功能概述三、自定义1. 自定义“研发需求”2. 自定义“任务”3. 自定义“Bug”4. 自定义“用例”5. 自定义“测试单”6. 自定义“待办”7. 自定义“用户”8. 自定义“必填项” 总结 前言 禅道是一款国产开源的项目管理软件&#xff0c;它基…

公网环境调试本地配置的Java支付宝沙箱环境模拟支付场景

文章目录 前言1. 下载当面付demo2. 修改配置文件3. 打包成web服务4. 局域网测试5. 内网穿透6. 测试公网访问7. 配置二级子域名8. 测试使用固定二级子域名访问 前言 在沙箱环境调试支付SDK的时候&#xff0c;往往沙箱环境部署在本地&#xff0c;局限性大&#xff0c;在沙箱环境…

揭开Spring MVC的真面目

官方对于Spring MVC的描述为&#xff1a; Spring Web MVC是基于Servlet API框架构建的原始Web框架&#xff0c;从一开始就包含在Spring框架中。它的正式名称“Spring Web MVC”来自其源模块的名称&#xff08;Spring-webmvc&#xff09;&#xff0c;但它通常被称为“Spring-MVC…

【Gene Expression Prediction】Part1 基因表达数据的获取与分析

文章目录 Gene Expression Prediction1. Intro2. Up-sampling3. Compressive sensing3.5 Predicting Reporter Expression from Chromatin Features4. Predicting splicing from sequence 来自Manolis Kellis教授&#xff08;MIT计算生物学主任&#xff09;的课 YouTube&#x…