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

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

1. 背景

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

2. 实现原理

  1. 传统的单机登录

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

  2. 分布式登录

3. 代码实现

  1. 引入redis依赖

    xml 复制代码
    <!-- 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进行配置

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

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

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

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

  6. 启动两个服务

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

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

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

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

    java 复制代码
    @SpringBootApplication(exclude = {RedisAutoConfiguration.class})

总结:

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

相关推荐
瀚高PG实验室4 小时前
拼接符“II”在Oracle和HGDB中使用的差异
数据库·oracle·瀚高数据库
心态还需努力呀4 小时前
当时序数据不再“只是时间”:金仓数据库如何在复杂场景中拉开与 InfluxDB 的差距
数据库
宇灬宇4 小时前
oracle误drop表,通过回收站恢复
数据库·oracle
Albert Tan4 小时前
Oracle EBS 12.2/12.1 开放本地或远程访问Weblogic
数据库·oracle
一个处女座的程序猿O(∩_∩)O4 小时前
从InfluxDB到金仓:时序数据库性能拐点已至?
数据库·时序数据库
超级大只老咪4 小时前
“和”与“或”逻辑判断与条件取反(Java)
java·算法
青云交4 小时前
Java 大视界 -- 基于 Java+Flink 构建实时电商交易风控系统实战(436)
java·redis·flink·规则引擎·drools·实时风控·电商交易
程序员卷卷狗4 小时前
Java 单例模式的五种实现:饿汉式、懒汉式、DCL、静态内部类、枚举单例
java·开发语言·单例模式
数据和云4 小时前
Oracle没有退路
数据库·oracle·vr
@淡 定4 小时前
动态代理(JDK动态代理/CGLIB动态代理
java·开发语言·python