您好,登錄后才能下訂單哦!
怎么為Java項目添加Redis緩存?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
首先在linux下安裝docker,在docker環境下安裝redis5.0的鏡像
docker pull redis:5.0
然后使用Docker命令啟動Redis容器
docker run -p 6379:6379 --name redis \ -v /mydata/redis/data:/data \ -d redis:5.0 redis-server --appendonly yes
在redis官網下載windows版本的Redis
Redis下載鏈接
解壓到指定目錄
在當前地址欄輸入cmd,或者用Win+Rd打開命令提示符,輸入cmd,利用cd指令進入當前目錄 執行redis的啟動命令
redis-server.exe redis.windows.conf
默認的ip地址是127.0.0.1,默認端口號為6379
將Redis注冊為服務的命令:
#注冊服務 redis-server --service-install redis.windows.conf #啟動服務 redis-server --service-start #停止服務 redis-server --service-stop #刪除服務 redis-server --service-uninstall
Spring cache
Spring cache是SpringBoot融合Redis作為緩存最簡單的實現方式之一,我們無需關注spring具體操作redis的過程,只需要使用它提供的@Cacheable 、@CachePut 、@CacheEvict 、@EnableCaching等注解就可以實現緩存功能
基本注解 @EnableCaching
開啟緩存功能,一般放在啟動類上。
@Cacheable
使用該注解的方法當緩存存在時,會從緩存中獲取數據而不執行方法,當緩存不存在時,會執行方法并把返回結果存入緩存中。一般使用在查詢方法上,可以設置如下屬性:
value:緩存名稱(必填),指定緩存的命名空間;
key:用于設置在命名空間中的緩存key值,可以使用SpEL表達式定義;
unless:條件符合則不緩存;
condition:條件符合則緩存。
@CachePut
使用該注解的方法每次執行時都會把返回結果存入緩存中。一般使用在新增方法上,可以設置如下屬性:
value:緩存名稱(必填),指定緩存的命名空間;
key:用于設置在命名空間中的緩存key值,可以使用SpEL表達式定義;
unless:條件符合則不緩存;
condition:條件符合則緩存。
@CacheEvict
使用該注解的方法執行時會清空指定的緩存。一般使用在更新或刪除方法上,可以設置如下屬性:
value:緩存名稱(必填),指定緩存的命名空間;
key:用于設置在命名空間中的緩存key值,可以使用SpEL表達式定義;
condition:條件符合則緩存。
1.引入依賴
在pom.xml中引入redis對應依賴
<!-- redis--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>
2.配置Redis屬性
修改配置文件application.yml,添加Redis的連接配置
spring: redis: host: 127.0.0.1 # Redis服務器地址(默認地址) database: 0 # Redis數據庫索引(默認為0) port: 6379 # Redis服務器連接端口 password: # Redis服務器連接密碼(默認為空) timeout: 1000ms # 連接超時時間
3.在啟動類上添加@EnableCaching注解
4.在ServiceImpl類中使用相關注解來實現緩存功能 查詢(Cacheable)
修改/刪除(CacheEvict)
新增(CachePut)
5.儲存JSON格式數據
如果不對redis中數據格式進行設置,緩存的內容將類似亂碼形式,我們可以通過給RedisTemplate設置JSON格式的序列化器,并通過配置RedisCacheConfiguration設置超時時間,在Redis中儲存標準JSON數據,通過過期時間篩選不必要的緩存,節約空間
在config中新建BaseRedisConfig配置類
@Configuration public class BaseRedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) { RedisSerializer<Object> serializer = redisSerializer(); RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(redisConnectionFactory); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(serializer); redisTemplate.setHashKeySerializer(new StringRedisSerializer()); redisTemplate.setHashValueSerializer(serializer); redisTemplate.afterPropertiesSet(); return redisTemplate; } @Bean public RedisSerializer<Object> redisSerializer() { //創建JSON序列化器 Jackson2JsonRedisSerializer<Object> serializer = new Jackson2JsonRedisSerializer<>(Object.class); ObjectMapper objectMapper = new ObjectMapper(); objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); //必須設置,否則無法將JSON轉化為對象,會轉化成Map類型 objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL); serializer.setObjectMapper(objectMapper); return serializer; } @Bean public RedisCacheManager redisCacheManager(RedisConnectionFactory redisConnectionFactory) { RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory); //設置Redis緩存有效期為1天 RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig() .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer())).entryTtl(Duration.ofDays(1)); return new RedisCacheManager(redisCacheWriter, redisCacheConfiguration); } @Bean public RedisService redisService() { return new RedisServiceImpl(); } }
6.測試Redis緩存是否成功
我們可以利用postman測試一下接口
再通過Redis Desktop Manager查看一下Redis數據庫中是否已存入對應緩存數據
Java中的集合主要分為四類:1、List列表:有序的,可重復的;2、Queue隊列:有序,可重復的;3、Set集合:不可重復;4、Map映射:無序,鍵唯一,值不唯一。
關于怎么為Java項目添加Redis緩存問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。