自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SpringBoot中整合Redis(緩存篇)

開發(fā) 后端 其他數(shù)據(jù)庫 Redis
將用戶頻繁訪問的內(nèi)容存放在離用戶最近,訪問速度最快的地方,提高用戶的響應(yīng)速度,今天先來講下在springboot中整合redis的詳細(xì)步驟。

實(shí)際開發(fā)中緩存處理是必須的,不可能我們每次客戶端去請求一次服務(wù)器,服務(wù)器每次都要去數(shù)據(jù)庫中進(jìn)行查找,為什么要使用緩存?說到底是為了提高系統(tǒng)的運(yùn)行速度。將用戶頻繁訪問的內(nèi)容存放在離用戶最近,訪問速度最快的地方,提高用戶的響應(yīng)速度,今天先來講下在springboot中整合redis的詳細(xì)步驟。

一、安裝

redis下載地址:

https://redis.io/download

首先要在本地安裝一個redis程序,安裝過程十分簡單(略過),安裝完成后進(jìn)入到redis文件夾中可以看到如下:

點(diǎn)擊redis-server.exe開啟redis服務(wù),可以看到如下圖所示即代表開啟redis服務(wù)成功:

那么我們可以開啟redis客戶端進(jìn)行測試:

二、整合到springboot

1、在項目中加入redis依賴,pom文件中添加如下: 

  1. <!-- 整合Redis緩存支持 -->  
  2.         <dependency>  
  3.             <groupId>org.springframework.boot</groupId>  
  4.             <artifactId>spring-boot-starter-data-redis</artifactId>  
  5.         </dependency> 

2、在application.yml中添加redis配置: 

  1. ##默認(rèn)密碼為空  
  2. redis:  
  3.       host: 127.0.0.1  
  4.       # Redis服務(wù)器連接端口  
  5.       port: 6379  
  6.       jedis:  
  7.         pool:  
  8.           #連接池最大連接數(shù)(使用負(fù)值表示沒有限制)  
  9.           max-active: 100  
  10.           # 連接池中的最小空閑連接  
  11.           max-idle: 10  
  12.           # 連接池最大阻塞等待時間(使用負(fù)值表示沒有限制)  
  13.           max-wait: 100000  
  14.       # 連接超時時間(毫秒)  
  15.       timeout: 5000  
  16.       #默認(rèn)是索引為0的數(shù)據(jù)庫  
  17.       database: 0  

3、新建RedisConfiguration配置類,繼承CachingConfigurerSupport,@EnableCaching開啟注解 

  1. @Configuration  
  2. @EnableCaching  
  3. public class RedisConfiguration extends CachingConfigurerSupport {  
  4.     /**  
  5.      * 自定義生成key的規(guī)則  
  6.      */  
  7.     @Override  
  8.     public KeyGenerator keyGenerator() {  
  9.         return new KeyGenerator() {  
  10.             @Override  
  11.             public Object generate(Object o, Method method, Object... objects) {  
  12.                 //格式化緩存key字符串  
  13.                 StringBuilder sb = new StringBuilder();  
  14.                 //追加類名  
  15.                 sb.append(o.getClass().getName());  
  16.                 //追加方法名  
  17.                 sb.append(method.getName());  
  18.                 //遍歷參數(shù)并且追加  
  19.                 for (Object obj : objects) {  
  20.                     sb.append(obj.toString());  
  21.                 }  
  22.                 System.out.println("調(diào)用Redis緩存Key : " + sb.toString());  
  23.                 return sb.toString();  
  24.             }  
  25.         };  
  26.     }   
  27.     /**  
  28.      * 采用RedisCacheManager作為緩存管理器  
  29.      * @param connectionFactory  
  30.      */  
  31.     @Bean  
  32.     public CacheManager cacheManager(RedisConnectionFactory connectionFactory) {  
  33.         RedisCacheManager redisCacheManager = RedisCacheManager.create(connectionFactory);  
  34.         return  redisCacheManager;  
  35.     }  
  36.     @Bean  
  37.     public RedisTemplate<String, String> redisTemplate(RedisConnectionFactory factory) {  
  38.         ////解決鍵、值序列化問題  
  39.         StringRedisTemplate template = new StringRedisTemplate(factory);  
  40.         Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);  
  41.         ObjectMapper om = new ObjectMapper(); 
  42.          om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);  
  43.         om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);  
  44.         jackson2JsonRedisSerializer.setObjectMapper(om);  
  45.         template.setValueSerializer(jackson2JsonRedisSerializer);  
  46.         template.afterPropertiesSet();  
  47.         return template;  
  48.     }  

4、創(chuàng)建自定義的接口來定義需要的redis的功能 

  1. /**  
  2.  * K 指以hash結(jié)構(gòu)操作時 鍵類型  
  3.  * T 為數(shù)據(jù)實(shí)體 應(yīng)實(shí)現(xiàn)序列化接口,并定義serialVersionUID * RedisTemplate 提供了五種數(shù)據(jù)結(jié)構(gòu)操作類型 hash / list / set / zset / value  
  4.  * 方法命名格式為 數(shù)據(jù)操作類型 + 操作 如 hashPut 指以hash結(jié)構(gòu)(也就是map)想key添加鍵值對   
  5.  */  
  6. public interface RedisHelper<HK, T> {  
  7.     /**  
  8.      * Hash結(jié)構(gòu) 添加元素 * @param key key * @param hashKey hashKey * @param domain 元素  
  9.      */  
  10.     void hashPut(String key, HK hashKey, T domain);  
  11.     /**  
  12.      * Hash結(jié)構(gòu) 獲取指定key所有鍵值對 * @param key * @return  
  13.      */  
  14.     Map<HK, T> hashFindAll(String key);   
  15.     /**  
  16.      * Hash結(jié)構(gòu) 獲取單個元素 * @param key * @param hashKey * @return  
  17.      */  
  18.     T hashGet(String key, HK hashKey);  
  19.     void hashRemove(String key, HK hashKey);  
  20.     /**  
  21.      * List結(jié)構(gòu) 向尾部(Right)添加元素 * @param key * @param domain * @return  
  22.      */  
  23.     Long listPush(String key, T domain);  
  24.     /**  
  25.      * List結(jié)構(gòu) 向頭部(Left)添加元素 * @param key * @param domain * @return  
  26.      */  
  27.     Long listUnshift(String key, T domain);  
  28.     /**  
  29.      * List結(jié)構(gòu) 獲取所有元素 * @param key * @return  
  30.      */  
  31.     List<T> listFindAll(String key);  
  32.     /**  
  33.      * List結(jié)構(gòu) 移除并獲取數(shù)組第一個元素 * @param key * @return  
  34.      */  
  35.     T listLPop(String key);  
  36.     /**  
  37.      * 對象的實(shí)體類  
  38.      * @param key  
  39.      * @param domain  
  40.      * @return  
  41.      */  
  42.     void valuePut(String key, T domain);  
  43.     /**  
  44.      * 獲取對象實(shí)體類  
  45.      * @param key  
  46.      * @return  
  47.      */  
  48.     T getValue(String key);  
  49.     void remove(String key);  
  50.     /**  
  51.      * 設(shè)置過期時間 * @param key 鍵 * @param timeout 時間 * @param timeUnit 時間單位  
  52.      */  
  53.     boolean expirse(String key, long timeout, TimeUnit timeUnit);  

下面是創(chuàng)建RedisHelperImpl進(jìn)行接口的實(shí)現(xiàn) 

  1. @Service("RedisHelper")  
  2. public class RedisHelperImpl<HK, T> implements RedisHelper<HK, T> {  
  3.     // 在構(gòu)造器中獲取redisTemplate實(shí)例, key(not hashKey) 默認(rèn)使用String類型  
  4.     private RedisTemplate<String, T> redisTemplate;  
  5.     // 在構(gòu)造器中通過redisTemplate的工廠方法實(shí)例化操作對象  
  6.     private HashOperations<String, HK, T> hashOperations;  
  7.     private ListOperations<String, T> listOperations;  
  8.     private ZSetOperations<String, T> zSetOperations;  
  9.     private SetOperations<String, T> setOperations;  
  10.     private ValueOperations<String, T> valueOperations;  
  11.     // IDEA雖然報錯,但是依然可以注入成功, 實(shí)例化操作對象后就可以直接調(diào)用方法操作Redis數(shù)據(jù)庫  
  12.     @Autowired  
  13.     public RedisHelperImpl(RedisTemplate<String, T> redisTemplate) {  
  14.         this.redisTemplate = redisTemplate;  
  15.         this.hashOperations = redisTemplate.opsForHash();  
  16.         this.listOperations = redisTemplate.opsForList();  
  17.         this.zSetOperations = redisTemplate.opsForZSet();  
  18.         this.setOperations = redisTemplate.opsForSet();  
  19.         this.valueOperations = redisTemplate.opsForValue();  
  20.     }  
  21.     @Override  
  22.     public void hashPut(String key, HK hashKey, T domain) {  
  23.         hashOperations.put(key, hashKey, domain);  
  24.     }  
  25.     @Override  
  26.     public Map<HK, T> hashFindAll(String key) {  
  27.         return hashOperations.entries(key);  
  28.     }  
  29.     @Override  
  30.     public T hashGet(String key, HK hashKey) {  
  31.         return hashOperations.get(key, hashKey);  
  32.     }  
  33.     @Override  
  34.     public void hashRemove(String key, HK hashKey) {  
  35.         hashOperations.delete(key, hashKey);  
  36.     } 
  37.     @Override  
  38.     public Long listPush(String key, T domain) {  
  39.         return listOperations.rightPush(key, domain);  
  40.     }  
  41.     @Override  
  42.     public Long listUnshift(String key, T domain) {  
  43.         return listOperations.leftPush(key, domain);  
  44.     }  
  45.     @Override  
  46.     public List<T> listFindAll(String key) {  
  47.         if (!redisTemplate.hasKey(key)) {  
  48.             return null;  
  49.         }  
  50.         return listOperations.range(key, 0, listOperations.size(key));  
  51.     }  
  52.     @Override  
  53.     public T listLPop(String key) {  
  54.         return listOperations.leftPop(key);  
  55.     }  
  56.     @Override  
  57.     public void valuePut(String key, T domain) {  
  58.         valueOperations.set(key, domain);  
  59.     }  
  60.     @Override  
  61.     public T getValue(String key) {  
  62.         return valueOperations.get(key);  
  63.     }  
  64.     @Override  
  65.     public void remove(String key) {  
  66.         redisTemplate.delete(key);  
  67.     }  
  68.     @Override  
  69.     public boolean expirse(String key, long timeout, TimeUnit timeUnit) {  
  70.         return redisTemplate.expire(key, timeout, timeUnit);  
  71.     }  

三、測試

編寫TestRedis類進(jìn)行測試 

  1. @RunWith(SpringRunner.class)  
  2. @SpringBootTest  
  3. public class TestRedis {  
  4.     @Autowired  
  5.     private StringRedisTemplate stringRedisTemplate;  
  6.     @Autowired  
  7.     private RedisTemplate redisTemplate;  
  8.     @Autowired  
  9.     private RedisHelperImpl redisHelper;  
  10.     @Test  
  11.     public void test() throws Exception{  
  12. //        基本寫法  
  13. //        stringRedisTemplate.opsForValue().set("aaa","111");  
  14. //        Assert.assertEquals("111",stringRedisTemplate.opsForValue().get("aaa"));  
  15. //        System.out.println(stringRedisTemplate.opsForValue().get("aaa"));  
  16.         Author user=new Author();  
  17.         user.setName("Alex");  
  18.         user.setIntro_l("不會打籃球的程序不是好男人");  
  19.         redisHelper.valuePut("aaa",user);  
  20.         System.out.println(redisHelper.getValue("aaa"));  
  21.     }  
  22.     @Test  
  23.     public void testObj() throws Exception {  
  24.         Author user=new Author();  
  25.         user.setName("Jerry"); 
  26.          user.setIntro_l("不會打籃球的程序不是好男人!");  
  27.         ValueOperations<String, Author> operations=redisTemplate.opsForValue();  
  28.         operations.set("502", user);  
  29.         Thread.sleep(500);  
  30.         boolean exists=redisTemplate.hasKey("502");  
  31.         if(exists){  
  32.             System.out.println(redisTemplate.opsForValue().get("502"));  
  33.         }else{  
  34.             System.out.println("exists is false");  
  35.         }  
  36.         // Assert.assertEquals("aa", operations.get("com.neo.f").getUserName());  
  37.     }  

運(yùn)行TestRedis測試類,結(jié)果如下:

注意:如果在RedisConfiguration中不配置redisTemplate(RedisConnectionFactory factory)注解,會造成鍵、值的一個序列化問題,有興趣的可以去試一下。序列化:序列化框架的選型和比對

四、項目實(shí)戰(zhàn)

首先需要在程序的入口處Application中添加@EnableCaching開啟緩存的注解 

  1. @EnableCaching  //開啟緩存  
  2. @SpringBootApplication  
  3. public class PoetryApplication {  
  4.     public static void main(String[] args) {  
  5.         SpringApplication.run(PoetryApplication.class, args);  
  6.     }  

上面的redis相關(guān)寫法是我們自定義設(shè)置并獲取的,那么我們經(jīng)常要在訪問接口的地方去使用redis進(jìn)行緩存相關(guān)實(shí)體對象以及集合等,那么我們怎么實(shí)現(xiàn)呢?

比如我現(xiàn)在想在AuthorController中去緩存作者相關(guān)信息的緩存數(shù)據(jù),該怎么辦呢?如下: 

  1. @RestController  
  2. @RequestMapping(value = "/poem" 
  3. public class AuthorController {  
  4.     private final static Logger logger = LoggerFactory.getLogger(AuthorController.class);  
  5.     @Autowired  
  6.     private AuthorRepository authorRepository;  
  7.     @Cacheable(value="poemInfo")  //自動根據(jù)方法生成緩存  
  8.     @PostMapping(value = "/poemInfo" 
  9.     public Result<Author> author(@RequestParam("author_id") int author_id, @RequestParam("author_name")String author_name) {  
  10.         if(StringUtils.isEmpty(author_id) || StringUtils.isEmpty(author_name)){  
  11.             return ResultUtils.error(ResultCode.INVALID_PARAM_EMPTY);  
  12.         }  
  13.         Author author;  
  14.         Optional<Author> optional = authorRepository.getAuthorByIdAndName(author_id, author_name);  
  15.         if (optional.isPresent()) {  
  16.             author = optional.get();  
  17.             //通過\n或者多個空格 進(jìn)行過濾去重  
  18.             if (!StringUtils.isEmpty(author.getIntro_l())) {  
  19.                 String s = author.getIntro_l();  
  20.                 String intro = s.split("\\s +")[0];  
  21.                 author.setIntro_l(intro);  
  22.             }  
  23.         } else {  
  24.            return ResultUtils.error(ResultCode.NO_FIND_THINGS);  
  25.         }  
  26.         return ResultUtils.ok(author);  
  27.     }  

這里 @Cacheable(value="poemInfo")這個注解的意思就是自動根據(jù)方法生成緩存,value就是緩存下來的key。到這里我們就已經(jīng)把redis整合到了springboot中了 

 

責(zé)任編輯:龐桂玉 來源: Java知音
相關(guān)推薦

2020-06-29 07:43:12

緩存RedisSpringBoot

2023-10-12 08:00:48

2015-12-28 10:48:44

RedisSpring緩存實(shí)例

2017-04-17 10:35:40

Spring BooRedis 操作

2023-01-13 07:39:07

2023-02-14 07:47:20

SpringBootEhcache

2025-04-21 03:00:00

2018-02-09 11:05:42

Java代碼框架

2023-08-09 08:01:00

WebSockett服務(wù)器web

2020-08-19 08:55:47

Redis緩存數(shù)據(jù)庫

2022-08-22 09:03:09

SpringbootRedis數(shù)據(jù)

2024-10-09 10:46:41

springboot緩存redis

2023-03-10 13:33:00

緩存穿透緩存擊穿緩存雪崩

2019-10-12 14:19:05

Redis數(shù)據(jù)庫緩存

2021-04-07 08:43:09

SpringBootRocketMQ開發(fā)技術(shù)

2022-05-27 07:57:20

緩存穿透緩存雪崩緩存擊穿

2024-04-09 10:02:13

Spring數(shù)據(jù)Redis

2019-03-28 11:07:56

Spring BootRedis緩存

2017-09-12 10:26:47

springbootmaven結(jié)構(gòu)

2020-04-23 15:08:41

SpringBootMyCatJava
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號