hash redis springboot_使用SpringBoot实现整合Redis

使用SpringBoot实现整合Redis

发布时间:2020-10-28 14:33:27

来源:亿速云

阅读:105

作者:Leah

使用SpringBoot实现整合Redis?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

redis是最常用的缓存数据库,常用于存储用户登录token、临时数据、定时相关数据等。

redis是单线程的,所以redis的操作是原子性的,这样可以保证不会出现并发问题。

redis基于内存,速度非常快,据测试,redis读的速度是110000次/s,写的速度是81000次/s

本节介绍SpringBoot引入redis,以及使用RedisTemplate来操作redis数据。

一、A Simple Demo-使用SpringBoot连接redis

maven:

org.springframework.boot

spring-boot-starter-data-redis

yml:

server:

port: 8867

spring:

redis:

host: localhost

port: 6379

#password: ''

database: 6

测试类:

@SpringBootTest

@RunWith(SpringRunner.class)

public class RedisTest {

@Autowired

private RedisTemplate redisTemplate;

@Test

public void testRedis() {

String key = "hello";

redisTemplate.opsForValue().set("hello", "你好");

String res = (String) redisTemplate.opsForValue().get(key);

System.out.println(res);

}

}

执行结果:

df4cb83e0d3c78abe5241cf8a5683b67.png

看一下redis:

492a484b984e3526e5a142ea11f090e0.png

这里存在一个问题:默认的存储方式导致key在redis-manager里面显示出来是乱码的,并且存储结果是二进制了。这样不利用我们查看redis里面的数据。

我们需要自定义redis存储的序列化规则。

二、解决RedisTemplate默认序列化的问题

完善一下maven:

org.springframework.boot

spring-boot-starter

org.springframework.boot

spring-boot-starter-test

test

org.springframework.boot

spring-boot-starter-web

org.springframework.boot

spring-boot-starter-data-redis

定义RedisConfig类:

/**

* redis配置

* 主要是配置Redis的序列化规则,替换默认的jdkSerializer

* key的序列化规则用StringRedisSerializer

* value的序列化规则用Jackson2JsonRedisSerializer

*/

@Configuration

public class RedisConfig {

@Bean

public RedisTemplate redisTemplate(RedisConnectionFactory connectionFactory) {

RedisTemplate redisTemplate = new RedisTemplate<>();

redisTemplate.setConnectionFactory(connectionFactory);

// 使用Jackson2JsonRedisSerialize替换默认序列化

Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);

ObjectMapper objectMapper = new ObjectMapper();

objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);

objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);

jackson2JsonRedisSerializer.setObjectMapper(objectMapper);

// 设置key和value的序列化规则

redisTemplate.setKeySerializer(new StringRedisSerializer());

redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);

redisTemplate.setHashKeySerializer(new StringRedisSerializer());

redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);

redisTemplate.afterPropertiesSet();

return redisTemplate;

}

}

删除之前的key,重新执行一下test方法:

d38e1262ae95ecd2e7ea0a1e4fc9b490.png

下面来演示一下SpringBoot使用RedisTemplate进行redis数据的操作

三、基于SpringBoot的redis操作——key/list/hash

RedisTemplate内置redis操作如下:

0bfd5adb22f6c97d3d09bfd53c2656b6.png

这里主要展示value/hash/list三种用法:

3.1 RedisTemplate.opsForValue

@Test

public void testKeyOps() {

// 测试redis操作key-value形式

Set keySet = new HashSet<>();

String key1 = "name";

keySet.add(key1);

// 存储简单的key-value,并设置过期时间

redisTemplate.opsForValue().set(key1, "eknown", 1, TimeUnit.MINUTES);

String key2 = "token:user1";

String key3 = "token:user2";

keySet.add(key2);

keySet.add(key3);

//

redisTemplate.opsForValue().set(key2, "{\"name\":\"eknown\"}, \"role\":\"admin\"");

redisTemplate.opsForValue().set(key3, "{\"name\":\"test\"}, \"role\":\"test\"");

// 根据key的集合获取多个value

List valueList = redisTemplate.opsForValue().multiGet(keySet);

for (String value : valueList) {

System.out.println(value);

}

}

执行结果:

ed9cfc0019951dd33a379ce43d4f78b7.png

redis中的数据:

92971d81e6db774562b6ee5b212451c2.png

redis中的key显示出了一个层级关系,这个小技巧对于实际项目有个非常好的作用:通过prefix:suffix这样的形式,可以将redis中存储的数据分出层级。

3.2 RedisTemplate.opsForHash

清空该database下的数据,测试redisTemplate.opsForHash:

@Test

public void testHashOps() {

String key = "hash";

// 单次往hash中存放一个数据

redisTemplate.opsForHash().put(key, "1", "你好");

Map map = new HashMap<>();

map.put("2", "hello");

map.put("3a", "china1=2");

// 一次性向hash中存放一个map

redisTemplate.opsForHash().putAll(key, map);

// 获取hash下的所有key和value

Map resultMap = redisTemplate.opsForHash().entries(key);

for (String hashKey : resultMap.keySet()) {

System.out.println(hashKey + ": " + resultMap.get(hashKey));

}

}

执行结果:

f1fa2e69cc175e3ebd0e4700dddeee7c.png

redis:

5b5f6f67bb3bb797d650473bc1bd8a84.png

3.3 RedisTemplate.opsForList

@Test

public void testListOps() {

String listKey = "list";

redisTemplate.opsForList().leftPush(listKey, "first value"); // 从list最左边插入数据

redisTemplate.opsForList().leftPush(listKey, "second value but left");

redisTemplate.opsForList().rightPush(listKey, 3); // 从list最右边插入数据

List list = new ArrayList<>();

list.add("hello");

list.add("http://www.eknown.cn");

list.add(23344);

list.add(false);

redisTemplate.opsForList().rightPushAll(listKey, list); // 从list右边批量插入数据

long size = redisTemplate.opsForList().size(listKey);

if (size > 0) {

for (int i = 0; i < size -1 ; i++) {

// 从list最左边开始读取list中的数据,注意pop会导致出栈,也就是数据被取出来了(redis中就没有这个值了)

// 此处我们读取size-1条数据,仅留下最后一条数据

System.out.println(i + ":" + redisTemplate.opsForList().leftPop(listKey).toString());

}

}

}

执行上面的脚本,注意在最后的读取list数据代码前面加一个断点,此时redis中是这样的:

7fc2a8283969bc58182a4f870fb64cd2.png

放开断点,程序继续执行,控制台如下:

cae486c495be230e99e77be6553b69fd.png

注意,此时redis中仅剩余最后一条数据,这是由于pop的问题,list中的数据被读取并删除了:

9ca2fe5942145ba31dfc59d18548d412.png

好了,这一节主要讲了SpringBoot引入redis,以及使用redis的一些基本操作和相关技巧,在此基础上,我们可以让我们的项目变得更加快速、灵活!

关于使用SpringBoot实现整合Redis问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值