Spring中的RedisTemplate如何使用
这篇文章主要介绍“Spring中的RedisTemplate如何使用”,在日常操作中,相信很多人在Spring中的RedisTemplate如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Spring中的RedisTemplate如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
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;@SpringBootTestpublic 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;@Configurationpublic 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对象,指定泛型类型
@Autowiredprivate RedisTemplate<String, String> redisTemplate;
不过方法a又有问题啦,去看String类型的key:name的值,
长长的一串,占用空间大,可读性差。这是因为value的序列化方式默认是JdkSerializationRedisSerializer,把它改成json。在上方的RedisConfig类中,添加代码:
redisTemplate.setValueSerializer(RedisSerializer.json());// 针对于hash类型的valueredisTemplate.setHashValueSerializer(RedisSerializer.json());
如果你的redisTemplate类型确定就是RedisTemplate<String, String>,那也可以用StringRedisTemplate,两者效果一样。
到此,关于“Spring中的RedisTemplate如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341