使用注解實(shí)現(xiàn)Redis緩存功能
本文實(shí)例為大家分享了使用注解實(shí)現(xiàn)Redis緩存功能的具體代碼,供大家參考,具體內(nèi)容如下
非關(guān)系型內(nèi)存數(shù)據(jù)庫(kù),有持久化操作,
c語(yǔ)言編寫(xiě)的key,value存儲(chǔ)系統(tǒng)(區(qū)別于MySQL的二維表格的形式存儲(chǔ)。)
rdb:周期性的持久化
aof:以日志形式追加
默認(rèn)rdb開(kāi)啟,同時(shí)開(kāi)啟使用aof
數(shù)據(jù)類(lèi)型:string、list、set、zset、hash、
bitMaps 字節(jié)形式存儲(chǔ)、geospatial 經(jīng)緯度類(lèi)型...
單線程:采用多路io復(fù)用實(shí)現(xiàn)高并發(fā)
使用:
添加依賴(lài)
<!-- redis --> <dependency> ?<groupId>org.springframework.boot</groupId> ?<artifactId>spring-boot-starter-data-redis</artifactId> </dependency> <!-- spring2.X集成redis所需common-pool2--> <dependency> ?<groupId>org.apache.commons</groupId> ?<artifactId>commons-pool2</artifactId> ?<version>2.6.0</version> </dependency>
創(chuàng)建配置類(lèi) 固定寫(xiě)法
package com.lzq.yygh.common;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.cache.CacheManager;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.cache.RedisCacheConfiguration;
import org.springframework.data.redis.cache.RedisCacheManager;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.RedisSerializationContext;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
?
import java.net.UnknownHostException;
import java.time.Duration;
@Configuration
@EnableCaching ?//開(kāi)啟緩存功能
public class RedisConfig {
/**
?* 設(shè)置RedisTemplate規(guī)則
?* @param redisConnectionFactory
?* @return
?*/
@Bean
public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory)throws UnknownHostException {
? ? RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<>();
? ? redisTemplate.setConnectionFactory(redisConnectionFactory);
? ? Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
? ? //解決查詢(xún)緩存轉(zhuǎn)換異常的問(wèn)題
? ? ObjectMapper om = new ObjectMapper();
? ? // 指定要序列化的域,field,get和set,以及修飾符范圍,ANY是都有包括private和public
? ? ?om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
? ? // 指定序列化輸入的類(lèi)型,類(lèi)必須是非final修飾的,final修飾的類(lèi),比如String,Integer等
? ? ? ? ? ? ? ? om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
? ? ?jackson2JsonRedisSerializer.setObjectMapper(om);
? ? //序列號(hào)key value
? ? ?redisTemplate.setKeySerializer(new StringRedisSerializer());
? ? ?redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
? ? ?redisTemplate.setHashKeySerializer(new StringRedisSerializer());
? ? ?redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
? ? ?redisTemplate.afterPropertiesSet();
? ? ?return redisTemplate;
}
? ? /**
? ? ?* 設(shè)置CacheManager緩存規(guī)則
? ? ?* @param factory
? ? ?* @return
? ? ?*/
? ? @Bean
? ? public CacheManager cacheManager(RedisConnectionFactory factory) {
? ? ? ? RedisSerializer<String> redisSerializer = new StringRedisSerializer();
? ? ? ? Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
? ? ? ? //解決查詢(xún)緩存轉(zhuǎn)換異常的問(wèn)題
? ? ? ? ObjectMapper om = new ObjectMapper();
? ? ? ? om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
? ? ? ? om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
? ? ? ? jackson2JsonRedisSerializer.setObjectMapper(om);
? ? ? ? // 配置序列化(解決亂碼的問(wèn)題),過(guò)期時(shí)間600秒
? ? ? ? RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
? ? ? ? ? ? ? ? .entryTtl(Duration.ofSeconds(600)) //緩存過(guò)期10分鐘 ---- 業(yè)務(wù)需求。
? ? ? ? ? ? ? ? .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))//設(shè)置key的序列化方式
? ? ? ? ? ? ? ? .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer)) //設(shè)置value的序列化
? ? ? ? ? ? ? ? .disableCachingNullValues();
? ? ? ? RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
? ? ? ? ? ? ? ? .cacheDefaults(config)
? ? ? ? ? ? ? ? .build();
? ? ? ? return cacheManager;
? ? }
}添加配置信息
spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.database= 0 spring.redis.timeout=1800000 spring.redis.lettuce.pool.max-active=20 spring.redis.lettuce.pool.max-wait=-1 #最大阻塞等待時(shí)間(負(fù)數(shù)表示沒(méi)限制) spring.redis.lettuce.pool.max-idle=5 spring.redis.lettuce.pool.min-idle=0
使用注解實(shí)現(xiàn)功能
緩存@Cacheable
根據(jù)方法對(duì)其返回結(jié)果進(jìn)行緩存,下次請(qǐng)求時(shí),如果緩存存在,則直接讀取緩存數(shù)據(jù)返 回;如果緩存不存在,則執(zhí)行方法,并把返回的結(jié)果存入緩存中。一般用在查詢(xún)方法 上。
緩存@CachePut
使用該注解標(biāo)志的方法,每次都會(huì)執(zhí)行,并將結(jié)果存入指定的緩存中。其他方法可以直 接從響應(yīng)的緩存中讀取緩存數(shù)據(jù),而不需要再去查詢(xún)數(shù)據(jù)庫(kù)。一般用在新增方法上。
緩存@CacheEvict
使用該注解標(biāo)志的方法,會(huì)清空指定的緩存。一般用在更新或者刪除方法上
在返回serviceimpl中標(biāo)注注解 沒(méi)設(shè)置key時(shí)會(huì)自動(dòng)加上參數(shù)作為key
@Cacheable(value = "dict", key = "'selectIndexList'+#id")
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
redis?for?windows?6.2.6安裝包最新步驟詳解
這篇文章主要介紹了redis?for?windows?6.2.6安裝包全網(wǎng)首發(fā),使用Windows計(jì)劃任務(wù)自動(dòng)運(yùn)行redis服務(wù),文章給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04
關(guān)于Redis未授權(quán)訪問(wèn)漏洞利用的介紹與修復(fù)建議
Redis是一個(gè)開(kāi)源的使用ANSI C語(yǔ)言編寫(xiě)、支持網(wǎng)絡(luò)、可基于內(nèi)存亦可持久化的日志型、Key-Value數(shù)據(jù)庫(kù),并提供多種語(yǔ)言的API,下面這篇文章主要給大家介紹了關(guān)于Redis未授權(quán)訪問(wèn)漏洞利用的介紹和修復(fù)建議,文中介紹的非常詳細(xì),需要的朋友可以參考下。2017-07-07
如何利用 Redis 實(shí)現(xiàn)接口頻次限制
這篇文章主要介紹了如何利用 Redis 實(shí)現(xiàn)接口頻次限制,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
Redis 數(shù)據(jù)類(lèi)型Streams詳解
Redis Streams是Redis 5.0新增的數(shù)據(jù)類(lèi)型,提供了一種日志結(jié)構(gòu)化數(shù)據(jù)存儲(chǔ)方式,這種類(lèi)型適合用于構(gòu)建消息隊(duì)列、事件日志和處理時(shí)間序列數(shù)據(jù)的應(yīng)用,本文介紹Redis 數(shù)據(jù)類(lèi)型Streams相關(guān)知識(shí),感興趣的朋友一起看看吧2024-10-10
Redis5之后版本的高可用集群搭建的實(shí)現(xiàn)
這篇文章主要介紹了Redis5之后版本的高可用集群搭建的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04

