Spring中RedisTemplate的基本使用浅析
作者:尚少 发布时间:2023-03-08 05:46:50
spring-data-redis项目
  spring-data-redis提供了在Spring应用中通过简单的配置访问redis服务,封装了 RedisTemplate 对象来对Redis进行各种操作、异常处理及序列化,支持发布订阅。RedisTemplate对应于Redis五大数据类型的api:
Api | 返回值类型 | 说明 |
---|---|---|
redisTemplate.opsForValue() | ValueOperations | 操作 String 类型数据 |
redisTemplate.opsForHash() | HashOperations | 操作 Hash 类型数据 |
redisTemplate.opsForList() | ListOperations | 操作 List 类型数据 |
redisTemplate.opsForSet() | SetOperations | 操作 Set 类型数据 |
redisTemplate.opsForZSet() | ZSetOperations | 操作 SortedSet 类型数据 |
使用步骤
  前提条件:运行着的Redis(有windows版本)
  引入依赖:
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>2.7.3</version>
</dependency>
<!--SpringBoot项目,可以引入这个依赖,这个依赖也是会依赖spring-data-redis的-->
<!--<dependency>-->
<!-- <groupId>org.springframework.boot</groupId>-->
<!-- <artifactId>spring-boot-starter-data-redis</artifactId>-->
<!-- <version>2.7.4</version>-->
<!--</dependency>-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<version>2.7.4</version>
</dependency>
  application.yml配置Redis的信息:
spring:
redis:
host: 127.0.0.1
port: 6379
# 没有密码可以注释掉
password: 123456
database: 0
lettuce:
pool:
# 最大连接
max-active: 8
# 最大空闲连接
max-idle: 8
# 最小空闲连接
min-idle: 0
# 连接等待时间
max-wait: 100ms
  demo使用:
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.DefaultTypedTuple;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ZSetOperations;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
@SpringBootTest
public class RedisDemoApplicationTest {
// 注入RedisTemplate
@Autowired
private RedisTemplate redisTemplate;
// String类型
@Test
void testString () {
redisTemplate.opsForValue().set("name", "javaCoder");
Object name = redisTemplate.opsForValue().get("name");
System.out.println(name);
}
// Hash类型
@Test
public void testHash () {
redisTemplate.opsForHash().put("hash", "name", "abc");
redisTemplate.opsForHash().put("hash", "age", 18);
Map map = redisTemplate.opsForHash().entries("hash");
System.out.println(map);
}
// List类型
@Test
public void testList () {
redisTemplate.opsForList().leftPushAll("list", "zhangsan", "li",
"wanger");
List<String> names = redisTemplate.opsForList().range("list", 0,
-1);
System.out.println(names);
}
// Set类型
@Test
public void testSet () {
redisTemplate.opsForSet().add("set", "cat", "dog", "wolf", "pig",
"sheep");
Set<String> set = redisTemplate.opsForSet().members("set");
System.out.println(set);
}
// SortedSet类型
@Test
public void testSortedSet () {
redisTemplate.opsForZSet().add("zset", "cat", 30);
redisTemplate.opsForZSet().add("zset", "dog", 20);
redisTemplate.opsForZSet().add("zset", "wolf", 80);
redisTemplate.opsForZSet().add("zset", "pig", 40);
Set<String> aClass = redisTemplate.opsForZSet().range("zset",
0, -1);
System.out.println(aClass);
//使用下面这套写法,也行
//Set<ZSetOperations.TypedTuple<String>> set = new HashSet<>();
//set.add(new DefaultTypedTuple<>("cat", 30.0));
//set.add(new DefaultTypedTuple<>("dog", 20.0));
//set.add(new DefaultTypedTuple<>("wolf", 80.0));
//set.add(new DefaultTypedTuple<>("pig", 40.0));
//redisTemplate.opsForZSet().add("zset", set);
//Set<String> aClass1 = redisTemplate.opsForZSet().range("zset",
//0, -1);
//System.out.println(aClass1);
}
}
  此时代码运行起来没问题,但用redis-cli客户端,用相关命令去查看时,发现数据不存在(get name、hgetall hash、lrange list 0 -1、smembers set、zrange zset 0 -1),用如下解决方法:
  a.设置RedisTemplate对象的key的序列化方式
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.RedisSerializer;
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<String, Object> redisTemplate(
RedisConnectionFactory connectionFactory) {
// 创建 RedisTemplate 对象
RedisTemplate<String, Object> redisTemplate =
new RedisTemplate<>();
// 设置连接工厂
redisTemplate.setConnectionFactory(connectionFactory);
// 设置Key的序列化 - String 序列化 RedisSerializer.string() =>
// StringRedisSerializer.UTF_8
redisTemplate.setKeySerializer(RedisSerializer.string());
redisTemplate.setHashKeySerializer(RedisSerializer.string());
// 返回
return redisTemplate;
}
}
  b.注入的RestTemplate对象,指定泛型类型
@Autowired
private RedisTemplate<String, String> redisTemplate;
  不过方法a又有问题啦,去看String类型的key:name的值,
  长长的一串,占用空间大,可读性差。这是因为value的序列化方式默认是JdkSerializationRedisSerializer,把它改成json。在上方的RedisConfig类中,添加代码:
redisTemplate.setValueSerializer(RedisSerializer.json());
// 针对于hash类型的value
redisTemplate.setHashValueSerializer(RedisSerializer.json());
  如果你的redisTemplate类型确定就是RedisTemplate<String, String>,那也可以用StringRedisTemplate,两者效果一样。
来源:https://blog.csdn.net/gs2436/article/details/128743043


猜你喜欢
- 前几天用phonegap编译GameBuilder+CanTK时,发现HTML里的viewport无效。CanTK根据devicePixel
- 本文实例讲述了C#实现导出List数据到xml文件的方法。分享给大家供大家参考,具体如下:C#导出List数据到xml文件,这里主要用到的是
- 一、什么是队列队列是一个有序列表,可以用数组或者链表来实现。遵循先入先出的原则,即:先存入队列的数据,要先取出。后存入的的数据,后取出。看一
- AndroidManifest.xml <uses-feature>和<uses-permisstion>分析及比较
- SpringMVC中的 * 用于拦截控制器方法的执行,执行在Controller前后,和视图渲染完成后。如下图所示:一、创建 * 继承Han
- 这篇文章主要介绍了java获取当前时间的四种方法代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的
- 本文实例为大家分享了Android 自定义弹窗提示的具体代码,供大家参考,具体内容如下Java文件:private void showSet
- 鼠标事件监听机制的三个方面:1.事件源对象:事件源对象就是能够产生动作的对象。在Java语言中所有的容器组件和元素组件都是事件监听中的事件源
- 使用PHP开发的同学都知道array_chunk函数,其作用是将数据进行切割分段,但是在 java中却找不到合适的给List和Map分段的函
- import net.sourceforge.pinyin4j.PinyinHelper;import net.sourceforge.pi
- 本文实例讲述了Android实现基于滑动的SQLite数据分页加载技术。分享给大家供大家参考,具体如下:main.xml如下:<men
- 静默安装就是偷偷的把一个应用安装到手机上,就是屏蔽确认框,通过反射只能写个主要的代码,这个是在linux编译用到,因为静默安装需要调用系统服
- JavaScript 中需要创建函数的话,有两种方法:函数声明、函数表达式,各自写法如下:// 方法一:函数声明function foo()
- Java 方法执行时的动态分派和静态分派是 Java 实现多态的本质背景Java 的动态分派和静态分派也是 Java 方法的执行原理。 Ja
- 在java中可有两种方式实现多线程,一种是继承Thread类,一种是实现Runnable接口;Thread类是在java.lang包中定义的
- JAVA反射机制JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方
- Android强制异步转同步方法,供大家参考,具体内容如下Android系统中规定耗时任务需要在异步线程中进行,特别是网络请求必须在异步线程
- 前言从本篇文章开始,我们将逐步开始分析Consumer的源码,首先我们将整体介绍Consumer的接口和相关实现类以及DefaultMQPu
- Home键(小房子键)在键盘上映射的就是home键,这倒是很好记。Menu键用于打开菜单的按键,在键盘上映射的是F2键,PgUp键同样可以。
- 前几天写了一篇《SpringBoot如何统一后端返回格式?老鸟们都是这样玩的!》阅读效果还不错,而且被很多号主都转载过,今天我们继续第二篇,