首页 > 数据库 >【SpringBoot】集成Redis

【SpringBoot】集成Redis

时间:2024-08-01 23:17:59浏览次数:17  
标签:集成 https SpringBoot Redis redis session key docker

目录

1 redis

​ redis是一个用C语言开发的,基于内存结构进行键值对数据存储、高性能、非关系型NoSQL数据库

​ 官网: https://redis.io/

1.1 特点

  • 基于内存存储,数据读写效率很高
  • 本身支持持久化
  • 虽然基于key-value存储,但是支持多种数据类型
  • 支持集群、支持主从模式

1.2 支持的数据类型

Redis是以键值对形式,进行数据存储,同时value也支持多种数据类型

  • String 字符串
  • hash 映射
  • list 列表
  • set 集合
  • zset 有序集合

image-20231217202241489

1.3 应用场景

  • 分布式会话
    在分布式系统中,可以使用redis实现session(共享缓存)

  • 缓存
    提高访问数据、降低数据库压力

  • 分布式锁
    基于redis的操作特征,可以实现分布式锁功能

  • 点赞、排行榜、计数器
    对数据实时读写要求比较高,但对数据库一致性要求不是很高的功能场景

  • 消息中间件
    实现应用之间的通信

2 安装redis

官网上有根据windows、linux、mac 等环境安装redis,这里主要介绍docker安装方式,操作更加方便好用

2.1 docker

3 可视化软件

3.1 Redis Desktop Manager(RDM)

https://docs.resp.app/en/latest/install/

3.2 QuickRedis (推荐)

​ 是一款国产开源的 免费 Redis 可视化管理工具,支持直连、哨兵、集群模式,支持亿万数量级的 key,支持 Windows 、 Mac OS X 和 Linux 下运行。

4 SpringBoot集成

4.1 引入redis

​ 打开pom.xml文件

<!-- 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.7.15</version>
</dependency>

4.2. 操作redis

4.2.1 直接操作

  • 定义stringRedisTemplate

    @Autowired
    private StringRedisTemplate stringRedisTemplate;
    
  • 写入

    // 过期时间,单位:分
    public final static int Redis_Key_Login_Expire_Time = 30  ; 
    
    public final static Straing key = 'key_1';
    public final static Straing content = '这是存储内容';
    
    stringRedisTemplate.boundValueOps(key).set(content, Constant.Redis_Key_Login_Expire_Time, TimeUnit.MINUTES);
    
  • 读取

    public final static Straing key = 'key_1';
    String content = stringRedisTemplate.boundValueOps(key).get();
    

4.3 分布式会话场景(Resis-Session)

​ 引入 spring-session 和 redis 的整合,使得自动将 session 存储到 redis 中

​ PS: 直接配置就好,不需要改动代码

  • 引入依赖包

    根据你的SpringBoot版本(我的v2.7.15)选择依赖,尽量保持一致

    <!-- 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.7.4</version>
    </dependency>
    
  • 修改application.yml配置

    • spring-session 存储配置
    • tore-type:
      • none : 默认值,表示存储在单台服务器上
      • Redis : 表示存储在redis上
    spring:
    	# redis 配置
       redis:
          host: localhost
          port: 6379
          password: 123456
          database: 2   # Redis共有16个数据(0-15)
          
      session:
          timeout: 86400  	# session失效时间,单位秒,1天
          store-type: redis # 指定存储方式
    
  • 调用

     public User doLogin(String userAccount, String userPassword, HttpServletRequest request) {
     		// ...
     		// 存储session
     		String key = "userLoginState";
     		String value = "这是存储内容"
     		request.getSession().setAttribute(key,value);
     		
     		return null;
     }
    
  • 存储成效果

    image-20231217211247464

本文由博客一文多发平台 OpenWrite 发布!

标签:集成,https,SpringBoot,Redis,redis,session,key,docker
From: https://www.cnblogs.com/leovany/p/18337778

相关文章

  • spring集成elasticsearch并实现基础功能
    什么是elasticsearch?Elasticsearch是一个基于Lucene的开源搜索引擎和分析引擎,它为结构化和非结构化的海量数据提供了实时的搜索、分析和可视化功能。Elasticsearch是ElasticStack(也称为ELKStack)的核心组件之一,其他组件还包括Kibana(用于数据可视化)、Logstash(用于数据......
  • Redis和Mysql如何保持数据一致性
    一般情况下,Redis是用来实现应用和数据库之间读操作得缓存层,主要目的是减少数据库IO,还可以提升数据的IO性能。当应用程序需要去读取某个数据时,会首先尝试去Redis里面加载,如果命中就直接返回,如果没有命中,就去从数据库中查询,查询到数据之后再把这个数据缓存到Redis里。 如果一......
  • 基于SpringBoot+Vue+uniapp的横向课题信息管理系统的详细设计和实现(源码+lw+部署文档
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......
  • 基于Java+SpringBoot+Vue的电竞交互管理系统设计与实现(源码+lw+部署文档+讲解等)
    文章目录前言项目运行截图技术框架后端采用SpringBoot框架前端框架Vue可行性分析系统测试系统测试的目的系统功能测试数据库表设计代码参考数据库脚本为什么选择我?获取源码前言......
  • 7.Redis的Hash类型
    Hash类型,也叫散列,其value是一个无序字典,类似于HashMap结构。问题String结构是将对象序列化为json字符串后存储,当需要修改对象某个字段是不是很方便。key                            value(将java对象序列化为json......
  • 4.Redis数据结构&通用命令
    Redis数据结构Redis是一个键值对的数据库。key:大多都是Stringvalue:类型多种多样 Redis通用命令keys:查看所有的key不建议在生产环境上使用keys命令,因为redis是单线程的,keys命令会搜索很长一段时间,搜索的期间redis无法执行其他的命令,等于服务被阻塞了,影响redis的性......
  • SpringBoot+Vue物流快递仓库管理系统-附源码与配套论文
    1.1研究背景 随着网络不断的普及发展,物流快递仓库管理系统依靠网络技术的支持得到了快速的发展,首先要从员工的实际需求出发,通过了解员工的需求开发出具有针对性的首页、个人中心、员工管理、客户信息管理、驾驶员管理、仓库管理、配送管理、运输管理管理等功能,利用目前网络给......
  • docker 安装 redis
    1、拉取redisdockerpullredis2、配置redis路径mkdir-p/data/redis/confmkdir-p/data/redis/data#配置redis.conf#bind192.168.1.10010.0.0.1#bind127.0.0.1::1#bind127.0.0.1protected-modenoport6379tcp-backlog511requirepass000415timeout0tcp-keepal......
  • Redis过期key的删除策略
    在Redis中,设置了过期时间的键在过期时间到达后,并不会立即从内存中删除。如果不是,那过期后到底什么时候被删除呢?下面对这三种删除策略进行具体分析。立即删除:立即删除能够保证内存数据的及时性和空间的有效利用,但在处理大量过期键时,它可能会对系统性能产生负面影响。优点......
  • docker方式安装redis集群
    创建一个Redis集群,你需要按照一定的步骤来配置Docker容器和Redis实例。以下是详细的步骤来帮助你完成这个过程,并创建一个包含六台服务器的Redis集群。准备工作确保你已经安装了Docker和DockerCompose(可选但推荐)。创建Redis集群创建目录结构在主机上创建必要的......