SpringBoot中使用Redis的完整实例

一.在SpringBoot中使用Redis的一套军体拳

1.导包


<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-data-redis</artifactId>
 <version>2.2.0.RELEASE</version>
</dependency>

2.导入工具类

package com.cbsd.util;
import java.util.concurrent.TimeUnit;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.HashOperations;
import org.springframework.data.redis.core.ListOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.SetOperations;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.data.redis.core.ZSetOperations;
import org.springframework.stereotype.Component;

import com.alibaba.fastjson.JSON;

/**
 * redisTemplate封装
 *
 * @author gxp
 */
@Component
public class RedisUtil {
	// private Logger logger = LoggerFactory.getLogger(this.getClass());
 @Autowired
 private RedisTemplate<String, Object> redisTemplate;
 @Autowired
 private ValueOperations<String, String> valueOperations;
 @SuppressWarnings("unused")
 @Autowired
 private HashOperations<String, String, Object> hashOperations;
 @SuppressWarnings("unused")
 @Autowired
 private ListOperations<String, Object> listOperations;
 @SuppressWarnings("unused")
 @Autowired
 private SetOperations<String, Object> setOperations;
 @SuppressWarnings("unused")
	@Autowired
 private ZSetOperations<String, Object> zSetOperations;
 /** 默认过期时长,单位:秒 */
 public final static long DEFAULT_EXPIRE = 60 * 60 * 24;
 /** 不设置过期时长 */
 public final static long NOT_EXPIRE = -1;

 public void set(String key, Object value, long expire){

 valueOperations.set(key, toJson(value));
 if(expire != NOT_EXPIRE){
 redisTemplate.expire(key, expire, TimeUnit.SECONDS);
 }
 }

 public void set(String key, Object value){
 set(key, value, DEFAULT_EXPIRE);
 }

 public <T> T get(String key, Class<T> clazz, long expire) {
 String value = valueOperations.get(key);
 if(expire != NOT_EXPIRE){
 redisTemplate.expire(key, expire, TimeUnit.SECONDS);
 }
 return value == null ? null : fromJson(value, clazz);
 }

 public <T> T get(String key, Class<T> clazz) {
 return get(key, clazz, NOT_EXPIRE);
 }

 public String get(String key, long expire) {
 String value = valueOperations.get(key);
 if(expire != NOT_EXPIRE){
 redisTemplate.expire(key, expire, TimeUnit.SECONDS);
 }
 return value;
 }

 public String get(String key) {
 return get(key, NOT_EXPIRE);
 }

 public void delete(String key) {
 redisTemplate.delete(key);
 }

 /**
 * Object转成JSON数据
 */
 private String toJson(Object object){
 if(object instanceof Integer || object instanceof Long || object instanceof Float ||
 object instanceof Double || object instanceof Boolean || object instanceof String){
 return String.valueOf(object);
 }
 return JSON.toJSONString(object);
 }

 /**
 * JSON数据,转成Object
 */
 private <T> T fromJson(String json, Class<T> clazz){
 return JSON.parseObject(json, clazz);
 }
}

3.在SpringBoot的配置文件中配置redis的服务器

(1).yml配置文件中

spring:
 redis:
 open: true # 是否开启redis缓存 true开启 false关闭
 database: 0
 host: redis服务器地址
 port: redis服务器端口号
 password: redis服务器密码 # 密码(默认为空)
 timeout: 15000 # 连接超时时长(毫秒)
 jedis:
 pool:
 max-active: 1000 # 连接池最大连接数(使用负值表示没有限制)
 max-wait: -1 # 连接池最大阻塞等待时间(使用负值表示没有限制)
 max-idle: 10 # 连接池中的最大空闲连接
 min-idle: 5 # 连接池中的最小空闲连接

(2).properties配置文件中

#### 连接redis非关系型数据库配置
spring.redis.host=redis服务器地址
spring.redis.password=redis服务器密码,默认为空
spring.redis.port=redis服务器端口号
spring.redis.timeout=20000 //超时时间
spring.redis.database=6
spring.redis.lettuce.pool.min-idle=0
spring.redis.lettuce.pool.max-idle=3000
spring.redis.lettuce.pool.max-wait=10000
spring.redis.lettuce.pool.max-active=3000

4.使用

还是补上使用的方法吧

1.存入数据的方法

 /**
 *
 * @param key 同理map的key,可以根据对应的key取到对应的值
 * @param value 要存入redis的数据
 * @param expire 超时时间,就是数据会在redis里面存多久,可以不传,就是永不超时
 */
 public void set(String key, Object value, long expire){

 valueOperations.set(key, toJson(value));
 if(expire != NOT_EXPIRE){
 redisTemplate.expire(key, expire, TimeUnit.SECONDS);
 }
 }

2.取出数据的方法

 /**
 *
 * @param key 存入数据时,设置的key,根据可以取到对应的数据
 * @return
 */
 public String get(String key) {
 return get(key, NOT_EXPIRE);
 }

3.还有个删除

就是调用delete方法,跟get方法一样传一个key过去,就可以删除对应的数据了

到此这篇关于SpringBoot中使用Redis的文章就介绍到这了,更多相关SpringBoot使用Redis内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Spring框架接入单机Redis两种实现方式解析

    1.Redis的简单介绍 1)Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询. 这些数据类型都支持push/pop.add/remove及取交集并集和差集及更丰富的操作,而且

  • SpringBoot整合Redis正确的实现分布式锁的示例代码

    前言 最近在做分块上传的业务,使用到了Redis来维护上传过程中的分块编号. 每上传完成一个分块就获取一下文件的分块集合,加入新上传的编号,手动接口测试下是没有问题的,前端通过并发上传调用就出现问题了,并发的get再set,就会存在覆盖写现象,导致最后的分块数据不对,不能触发分块合并请求. 遇到并发二话不说先上锁,针对执行代码块加了一个JVM锁之后问题就解决了. 仔细一想还是不太对,项目是分布式部署的,做了负载均衡,一个节点的代码被锁住了,请求轮询到其他节点还是可以进行覆盖写,并没有解决到问题啊

  • 详解SpringBoot Redis自适应配置(Cluster Standalone Sentinel)

    核心代码段 提供一个JedisConnectionFactory  根据配置来判断 单点 集群 还是哨兵 @Bean @ConditionalOnMissingBean public JedisConnectionFactory jedisConnectionFactory() { JedisConnectionFactory factory = null; String[] split = node.split(","); Set<HostAndPort> nodes =

  • SpringBoot使用Redis实现分布式锁

    前言 在单机应用时代,我们对一个共享的对象进行多线程访问的时候,使用java的synchronized关键字或者ReentrantLock类对操作的对象加锁就可以解决对象的线程安全问题. 分布式应用时代这个方法却行不通了,我们的应用可能被部署到多台机器上,运行在不同的JVM里,一个对象可能同时存在多台机器的内存中,怎样使共享对象同时只被一个线程处理就成了一个问题. 在分布式系统中为了保证一个对象在高并发的情况下只能被一个线程使用,我们需要一种跨JVM的互斥机制来控制共享资源的访问,此时就需要用到

  • Spring Cache整合Redis实现方法详解

    导入依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-cache</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>

  • spring boot+redis 监听过期Key的操作方法

    前言: 在订单业务中,有时候需要对订单设置有效期,有效期到了后如果还未支付,就需要修改订单状态.对于这种业务的实现,有多种不同的办法,比如: 1.使用querytz,每次生成一个订单,就创建一个定时任务,到期后执行业务代码: 2.rabbitMq中的延迟队列: 3.对Redis的Key进行监控: 1.引入依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring

  • 多个SpringBoot项目采用redis实现Session共享功能

    有时我们可能有多个不同的Web应用,可以相互调用,这时如果每个应用都有自己的session,那用户跳转到另一个应用时就又需要登陆一次,这样会带来很不好的体验,因此我们需要在不同的应用中共享session.这里,我们采用redis来实现. 前置说明 由于只用到redis和springboot的整合,所以只能实现一个URL下的不同端口的应用之间的session共享,如果连应用名称都完全不同的两个应用要实现session共享,在这个基础上还需要使用到Nginx,这种方式我暂时还没有试过.(Spring

  • SpringBoot中使用redis做分布式锁的方法

    一.模拟问题 最近在公司遇到一个问题,挂号系统是做的集群,比如启动了两个相同的服务,病人挂号的时候可能会出现同号的情况,比如两个病人挂出来的号都是上午2号.这就出现了问题,由于是集群部署的,所以单纯在代码中的方法中加锁是不能解决这种情况的.下面我将模拟这种情况,用redis做分布式锁来解决这个问题. 1.新建挂号明细表 2.在idea上新建项目 下图是创建好的项目结构,上面那个parent项目是其他项目不用管它,和新建的没有关系 3.开始创建controller,service,dao(mapp

  • SpringBoot2.3整合redis缓存自定义序列化的实现

    1.引言 我们使用redis作为缓存中间件时,当我们第一次查询数据的时候,是去数据库查询,然后查到的数据封装到实体类中,实体类会被序列化存入缓存中,当第二次查数据时,会直接去缓存中查找被序列化的数据,然后反序列化被我们获取.我们在缓存中看到的序列化数据不直观,如果想看到类似json的数据格式,就需要自定义序列化规则. 2.整合redis pom.xml: <!--引入redis--> <dependency> <groupId>org.springframework.d

  • SpringBoot中使用Redis的完整实例

    一.在SpringBoot中使用Redis的一套军体拳 1.导包 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> <version>2.2.0.RELEASE</version> </dependency> 2.导入工具类 packag

  • springboot 中文件上传下载实例代码

    Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者. Spring Boot特点 1. 创建独立的Spring应用程序 2. 嵌入的Tomcat,无需部署WAR文件 3. 简化Maven配置 4. 自动配置Spr

  • springboot中使用redis由浅入深解析

    正文 很多时候,我们会在springboot中配置redis,但是就那么几个配置就配好了,没办法知道为什么,这里就详细的讲解一下 这里假设已经成功创建了一个springboot项目. redis连接工厂类 第一步,需要加上springboot的redis jar包 <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redi

  • springboot中使用redis的方法代码详解

    特别说明: 本文针对的是新版 spring boot 2.1.3,其 spring data 依赖为 spring-boot-starter-data-redis,且其默认连接池为 lettuce ​redis 作为一个高性能的内存数据库,如果不会用就太落伍了,之前在 node.js 中用过 redis,本篇记录如何将 redis 集成到 spring boot 中.提供 redis 操作类,和注解使用 redis 两种方式.主要内容如下: •docker 安装 redis •springboo

  • 在SpringBoot中添加Redis及配置方法

    在实际的开发中,会有这样的场景.有一个微服务需要提供一个查询的服务,但是需要查询的数据库表的数据量十分庞大,查询所需要的时间很长. 此时就可以考虑在项目中加入缓存. 引入依赖 在maven项目中引入如下依赖.并且需要在本地安装redis. <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifac

  • java、spring、springboot中整合Redis的详细讲解

    java整合Redis 1.引入依赖或者导入jar包 <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.9.0</version> </dependency> 2.代码实现 public class JedisTest { public static void main(String[]

  • SpringBoot中使用Redis作为全局锁示例过程

    目录 一.模拟没有锁情况下的资源竞争 二.使用redis加锁 微服务的项目中,一个服务我们启动多份,在不同的进程中.这些服务是无状态的,而由数据存储容器(mysql/redis/es)进行状态数据的持久化.这就会导致资源竞争,出现多线程的问题. 一.模拟没有锁情况下的资源竞争 public class CommonConsumerService { //库存个数 static int goodsCount = 900; //卖出个数 static int saleCount = 0; publi

  • springboot中使用redis并且执行调试lua脚本

    目录 原因: 1.创建一个基本的web项目 2.配置redis 3.测试redis 的lua脚本 4.技术点 5.调试方式 1.进入服务关闭关闭正在运行的服务器 2.从命令行启动redis 3.在lua脚本中增加打印 4.运行代码 6.总结 今天有个项目需要使用redis,并且有使用脚本的需求.但是因为之前没有写过,所以还有一点点不熟悉,今天记录一下. 原因: 原子操作,redis会将整个脚本作为一个整体执行,中间不会被其他命令插入. 1.创建一个基本的web项目 文件 ->新建 -> 项目,

  • 使用SpringBoot中整合Redis

    目录 SpringBoot中整合Redis SpringBoot整合Redis改不了database问题 SpringBoot中整合Redis 本次,我们以IDEA + SpringBoot作为 Java中整合Redis的使用 的测试环境,如果对创建SpringBoot项目有不清楚的地方,可以参考这篇文章:使用Idea创建我的第一个SpringBoot项目 首先,我们需要导入Redis的maven依赖 <!-- Redis的maven依赖包 -->         <dependency

随机推荐