使用Redis将单机登录改为分布式登录

2024-06-15 14:20

本文主要是介绍使用Redis将单机登录改为分布式登录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用Redis将单机登录改为分布式登录

1. 背景

​ 现在大多数的应用程序登录的方式都是必须满足分布式登录的效果,比如我们在一个客户端登录之后可以在另一个客户端上面共享当前用户的信息,这样在另一个客户端登录的时候就不用用户再次输入自己的账号密码进行登录,拥有更好的用户体验。并且现在大多的应用程序部署至少是在两台服务器以上,所以单服务器的部署方式很少,学会分布式登录的实现是非常有必要的。

2. 实现原理

  1. 传统的单机登录

    image-20240613152551250

    上面存在的问题就是只有单个的服务器,我们在登录的时候在服务器里面会创建一个session然后我们将用户的登录态设置到了session里面进行的存储,所以用户只能在当前服务器里面登录才会获取到当前登录用户的信息,如果换到了其他的服务器上面请求登录那就没有用户的登录信息需要重新进行登录用户的体验就不好,解决办法就是实现分布式session让用户能够在多端登录。

  2. 分布式登录

    image-20240613152627836

3. 代码实现

  1. 引入redis依赖

    <!-- redis -->
    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    <dependency><groupId>org.springframework.session</groupId><artifactId>spring-session-data-redis</artifactId>
    </dependency>
    
  2. yml文件中对redis进行配置

    ...session:store-type: redis  # 如果使用redis存储session必须在这里进行更改timeout: 2592000   # 30天过期# redis配置redis:database: 1host: localhostport: 6379  # 默认都是6379timeout: 5000password: 123456  # 默认也是123456
    ...
    
  3. win系统安装redis,我自己安装的是5x版本的,如果有需要的可以留言找我发安装包;

  4. 启动redis我们使用QuickRedis连接redis来可视化的管理Redis里面的内存数据;

    image-20240613155013590

  5. 将项目打包一份,注意更改端口号(因为我们要模拟两台服务器的场景,就必须将项目打包为jar包之后单独时候命令行启动)

    image-20240613191325611

    如果java -jar启动项目时报错没有主清单属性可以将pom文件中的skip值设置为false重新打包即可

  6. 启动两个服务

    // 启动jar包的命令    必须使用两个不同的端口号启动,否则会冲突
    java -jar  jar包位置
    
  7. 到在线接口测试文档中测试

    登录两个接口文档,一个测试登录,另一个服务测试是否能够在不登陆的情况下获取到对应的用户信息

    image-20240613192523663

    image-20240613192624770

    我们在82端口登录了之后,用户信息存储到了redis中,然后我们在80端口能够直接获取到登录之后存储的用户信息,就不用再重复登录了这样就实现了分布式登录,并且能够在可视化的redis软件中查看到我们的用户信息session

    image-20240613192912472

  8. 如果不想使用redis的话将yml里面的配置注释掉,然后再启动类里面的注解后面加上下面的内容

    @SpringBootApplication(exclude = {RedisAutoConfiguration.class})
    

总结:

​ 实现这个分布式session的过程是很简单的,只需要进行一些配置即可,最重要的是我们要知道其中的实现原理。它是将用户的session从服务器上存储到了redis中进行共享实现的。

这篇关于使用Redis将单机登录改为分布式登录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1063703

相关文章

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.

使用Python实现一键隐藏屏幕并锁定输入

《使用Python实现一键隐藏屏幕并锁定输入》本文主要介绍了使用Python编写一个一键隐藏屏幕并锁定输入的黑科技程序,能够在指定热键触发后立即遮挡屏幕,并禁止一切键盘鼠标输入,这样就再也不用担心自己... 目录1. 概述2. 功能亮点3.代码实现4.使用方法5. 展示效果6. 代码优化与拓展7. 总结1.

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Linux中的计划任务(crontab)使用方式

《Linux中的计划任务(crontab)使用方式》:本文主要介绍Linux中的计划任务(crontab)使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言1、linux的起源与发展2、什么是计划任务(crontab)二、crontab基础1、cro

kotlin中const 和val的区别及使用场景分析

《kotlin中const和val的区别及使用场景分析》在Kotlin中,const和val都是用来声明常量的,但它们的使用场景和功能有所不同,下面给大家介绍kotlin中const和val的区别,... 目录kotlin中const 和val的区别1. val:2. const:二 代码示例1 Java

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整