SpringBoot集成Redis用法笔记

存储 存储软件 Redis
今天给大家整理一下SpringBoot集成Redis用法笔记,希望对大家能有所帮助!不需要等待磁盘的IO,在内存之间进行的数据存储和查询,速度非常快。当然,缓存的数据总量不能太大,因为受到物理内存空间大小的限制。

[[410540]]

今天给大家整理一下SpringBoot集成Redis用法笔记,希望对大家能有所帮助!

一、Redis优点介绍

1、速度快

不需要等待磁盘的IO,在内存之间进行的数据存储和查询,速度非常快。当然,缓存的数据总量不能太大,因为受到物理内存空间大小的限制。

2、支持多种数据库类型

丰富的数据结构 除了string之外,还有list、hash、set、sortedset,一共五种类型。

3、单线程数据库

单线程,避免了线程切换和锁机制的性能消耗。

4、可持久化

支持RDB与AOF两种方式,将内存中的数据写入外部的物理存储设备。

5、支持发布/订阅。

6、支持Lua脚本。

7、支持分布式锁

在分布式系统中,如果不同的节点需要访同到一个资源,往往需要通过互斥机制来防止彼此干扰,并且保证数据的一致性。在这种情况下,需要使用到分布式锁。分布式锁和Java的锁用于实现不同线程之间的同步访问,原理上是类似的。

8、支持原子操作和事务Redis事务是一组命令的集合。

一个事务中的命令要么都执行,要么都不执行。如果命令在运行期间出现错误,不会自动回滚。

9、支持主从复制

支持主-从(Master-Slave)复制与高可用(Redis Sentinel)集群(3.0版本以上)

10、支持管道模式

支持管道Redis管道是指客户端可以将多个命令一次性发送到服务器,然后由服务器一次性返回所有结果。管道技术的优点是:在批量执行命令的应用场景中,可以大大减少网络传输的开销,提高性能。

11、支持多种编程语言

二、示例

1、下载redis

大家可以在官网下载 :https://redis.io/ ,有需要的话也可以留言直接发给大家。

然后启动redis。

2、引入依赖 pom.xml

  1. <!--redis依赖配置--> 
  2. <dependency> 
  3. <groupId>org.springframework.boot</groupId> 
  4. <artifactId>spring-boot-starter-data-redis</artifactId> 
  5. </dependency> 

 

3、增加配置

  1. redis: 
  2. host: localhost 
  3. database: 0 
  4.   port: 6379 
  5.   password
  6. jedis: 
  7. pool: 
  8. max-active: 8 
  9.       max-wait: -1ms 
  10. max-idle: 8 
  11.       min-idle: 0 
  12.   timeout: 3000ms 

4、示例代码

  1. package my.springboot.redis; 
  2.  
  3. import my.springboot.redis.entity.UserDO; 
  4. import my.springboot.redis.service.IUserInfoService; 
  5. import org.junit.Test; 
  6. import org.junit.runner.RunWith; 
  7. import org.springframework.beans.factory.annotation.Autowired; 
  8. import org.springframework.boot.test.context.SpringBootTest; 
  9. import org.springframework.data.redis.core.*; 
  10. import org.springframework.test.context.junit4.SpringRunner; 
  11.  
  12. import java.util.*; 
  13. import java.util.concurrent.TimeUnit; 
  14.  
  15.  
  16. /** 
  17.  * 测试UserInfo用法 
  18.  **/ 
  19. @RunWith(SpringRunner.class) 
  20. @SpringBootTest 
  21. public class RedisTest { 
  22. @Autowired 
  23. private RedisTemplate redisTemplate; 
  24. /*ValueOperations:简单K - V操作 
  25.     SetOperations:set类型数据操作 
  26.     ZSetOperations:zset类型数据操作 
  27.     HashOperations:针对map类型的数据操作 
  28.     ListOperations:针对list类型的数据操作*/ 
  29.  
  30. @Test 
  31. public void redisStrTest() { 
  32.         ValueOperations<String,Object> valueOperations = redisTemplate.opsForValue(); 
  33.         valueOperations.set("name1","小明"); 
  34.         valueOperations.set("name2","小李"); 
  35. System.out.println("删除前:"+valueOperations.get("name1")); 
  36. redisTemplate.delete("name1"); 
  37. //设置name1 60秒 过期 
  38.         redisTemplate.expire("name1",60, TimeUnit.SECONDS); 
  39.         System.out.println("删除后:"+valueOperations.get("name1")); 
  40.         UserDO user= new UserDO(); 
  41.         user.setId(1); 
  42.         user.setUserName("小明"); 
  43.         user.setPassword("123456"); 
  44.         valueOperations.set("user",user); 
  45.         UserDO user1=  (UserDO) valueOperations.get("user"); 
  46.  
  47.     } 
  48. @Test 
  49. public void redisListTest() { 
  50. ListOperations<String,List<String>> listOperations=redisTemplate.opsForList(); 
  51.         List<String> list=new ArrayList<>(); 
  52.         list.add("篮球"); 
  53.         list.add("足球"); 
  54.         listOperations.leftPushAll("list:str",list); 
  55.         List<String> ll=listOperations.range("list:str",0,-1).get(0); 
  56. long size= listOperations.size("list:str"); 
  57. for (String item: ll ) { 
  58.             System.out.println(item); 
  59.         } 
  60. // 移除操作 
  61.         redisTemplate.delete("list:str"); 
  62.         List<String> aa=listOperations.leftPop("list:str"); 
  63.         System.out.println(listOperations.leftPop("list:str")); 
  64.     } 
  65. @Test 
  66. public void redisHashTest() { 
  67.         HashOperations<String,Object,UserDO> hashOperations = redisTemplate.opsForHash(); 
  68.         UserDO user= new UserDO(); 
  69.         user.setId(1); 
  70.         user.setUserName("小明"); 
  71.         user.setPassword("123456"); 
  72.         hashOperations.put("user:hash",user.hashCode()+"",user); 
  73.         System.out.println(hashOperations.get("user:hash",user.hashCode()+"").getUserName()); 
  74.     } 
  75. @Test 
  76. public void redisSettTest() { 
  77.         SetOperations<String,UserDO> sortOperations = redisTemplate.opsForSet(); 
  78.         UserDO user= new UserDO(); 
  79.         user.setId(1); 
  80.         user.setUserName("小明"); 
  81.         user.setPassword("123456"); 
  82.  
  83.         UserDO user1= new UserDO(); 
  84.         user1.setId(2); 
  85.         user1.setUserName("小张"); 
  86.         user1.setPassword("888888"); 
  87.         sortOperations.add("user:sort",user,user1); 
  88.         Set<UserDO> result = sortOperations.members("user:sort"); 
  89. for (UserDO item : result ) { 
  90.             System.out.println(item.getUserName()); 
  91.  
  92.         } 
  93. redisTemplate.delete("user:sort"); 
  94.         System.out.println(result); 
  95.     } 
  96.  
  97. @Test 
  98. public void redisZSetTest() { 
  99. redisTemplate.delete("ranking-list"); 
  100.         ZSetOperations<String,String> zsortOperations = redisTemplate.opsForZSet(); 
  101. //向集合中插入元素,并设置分数 
  102.         zsortOperations.add("ranking-list""小明", 80); 
  103. //向集合中插入多个元素 
  104.         DefaultTypedTuple<String> tuple1 = new DefaultTypedTuple<String>("小王", 100.0); 
  105.         DefaultTypedTuple<String> tuple2 = new DefaultTypedTuple<String>("小张", 90.0); 
  106.         zsortOperations.add("ranking-list", new HashSet<>(Arrays.asList(tuple1, tuple2))); 
  107.  
  108.         System.out.println(zsortOperations.range("ranking-list",0,-1)); 
  109.  
  110.     } 
  111.  

原文链接:https://programmerblog.xyz

本文转载自微信公众号「IT技术分享社区」,可以通过以下二维码关注。转载本文请联系IT技术分享社区公众号。

 

责任编辑:武晓燕 来源: IT技术分享社区
相关推荐

2021-05-26 06:22:34

SpringBootJPA后端开发

2021-06-05 07:34:00

SpringBootMybatis用法

2023-02-14 07:47:20

SpringBootEhcache

2021-09-26 05:02:00

缓存Ehcache用法

2023-09-08 09:10:33

SpringBoot微服务架构

2023-08-07 14:28:07

SpringBoot工具

2023-01-11 15:11:36

SpringEhcache

2010-08-16 15:11:02

DIV

2010-08-26 16:40:35

DIV定位

2021-12-22 22:32:48

鸿蒙HarmonyOS应用

2010-09-14 16:20:19

DIV定位

2009-12-02 17:07:27

LINUX系统

2010-07-12 15:16:29

UML关联

2020-09-23 07:39:59

SpringBoot项目Redis

2010-08-25 15:15:52

CSSclip

2010-07-26 10:09:01

Perl split函

2022-08-31 07:24:56

Docker日志命令

2010-05-13 10:47:20

Collabnet S

2021-04-21 09:04:43

开发SpringBoot框架

2010-08-05 10:29:11

Flex效果
点赞
收藏

51CTO技术栈公众号