SpringBoot集成Redis流程詳解
第一步,導入jar包
<!--Redis-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!--Redis-->第二步,編寫配置類
這是一個使用FastJson序列化器,配置RedisTemplate的Spring Bean的Java類。該類使用了@Configuration注釋來標識這是一個配置類,并使用@Bean注釋來標識該方法是創(chuàng)建一個Bean的工廠方法。該方法名為redisTemplate,并使用了@ConditionalOnMissingBean注釋,表示如果在上下文中沒有StringRedisTemplate類型的Bean,則會自動創(chuàng)建一個該類型的Bean。該方法返回一個RedisTemplate類型的對象,該對象被配置為使用FastJson序列化器,以便將對象序列化為JSON格式進行存儲和檢索。在方法內(nèi)部,通過setConnectionFactory方法設置了RedisTemplate的連接工廠,并通過setKeySerializer和setValueSerializer方法設置了鍵和值的序列化器。此外,該類還提供了一個名為stringRedisTemplate的方法,用于創(chuàng)建StringRedisTemplate類型的Bean。
import com.alibaba.fastjson.support.spring.FastJsonRedisSerializer;
import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.JsonTypeInfo;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.serializer.StringRedisSerializer;
@Configuration
public class RedisConfig {
/**
* 重寫Redis序列化方式,使用Json方式: * 當我們的數(shù)據(jù)存儲到Redis的時候,我們的鍵(key)和值(value)
* 都是通過Spring提供的Serializer序列化到數(shù)據(jù)庫的。RedisTemplate默認使用的是JdkSerializationRedisSerializer,
* StringRedisTemplate默認使用的是StringRedisSerializer。
* Spring Data JPA為我們提供了下面的Serializer:
* GenericToStringSerializer、Jackson2JsonRedisSerializer、JacksonJsonRedisSerializer、
* JdkSerializationRedisSerializer、OxmSerializer、StringRedisSerializer。
* 在此我們將自己配置RedisTemplate并定義Serializer。
*
* @param redisConnectionFactory * @return
*/
@Bean("getRedisTemplate")
public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
/**
* 配置連接工廠
*/
redisTemplate.setConnectionFactory(redisConnectionFactory);
/**
* 使用FJackson2JsonRedisSerializer序列化工具
*/
FastJsonRedisSerializer fastJsonRedisSerializer = new FastJsonRedisSerializer(Object.class);
ObjectMapper objectMapper = new ObjectMapper();
/**
* 指定要序列化的域Field、set、get,以及修飾符范圍
* ANY是都有,包括private、public
*/
objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
/**
* 指定序列化輸入的類型,類必須是非final修飾的,
* final修飾的類,比如
* public final class User implements Serializable{},會包異常
*/
objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance,
ObjectMapper.DefaultTyping.NON_FINAL, JsonTypeInfo.As.PROPERTY);
/**
*設置鍵(key)的序列化采用StringRedisSerializer。
*/
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setHashKeySerializer(new StringRedisSerializer());
/**
* 設置值(value)的序列化采用jackson2JsonRedisSerializer。
*/
redisTemplate.setValueSerializer(fastJsonRedisSerializer);
redisTemplate.setHashValueSerializer(fastJsonRedisSerializer);
redisTemplate.afterPropertiesSet();
return redisTemplate;
}
/**
* 配置stringRedisTemplate序列化方式
*
* @param redisConnectionFactory
* @return
*/
@Bean
@ConditionalOnMissingBean(StringRedisTemplate.class)
public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
StringRedisTemplate template = new StringRedisTemplate();
template.setConnectionFactory(redisConnectionFactory);
return template;
}
}第三步,編寫util類
這段代碼是一個基于Spring框架和Redis實現(xiàn)的工具類,封裝了一些常見的操作方法。它依賴于另一個Redis配置類,通過@Autowired注解和@Qualifier注解來獲取到RedisTemplate實例,從而進行操作。
具體的操作方法有:
- set:設置鍵值對,將value存儲到key中。
- set:設置鍵值對并指定過期時間,將value存儲到key中,并設置過期時間。
- remove:刪除一個或多個key對應的值。
- exists:判斷指定的key是否存在于緩存中。
- get:獲取指定key對應的值。
需要注意的是,get方法返回的是一個經(jīng)過JSON序列化的字符串,而不是原始的對象。如果要使用對象,需要在調(diào)用get方法之后進行反序列化。
package com.wangfugui.apprentice.common.util;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.stereotype.Component;
import java.io.Serializable;
import java.util.concurrent.TimeUnit;
/**
* RedisUtils:redis工具類
*/
@Component
public class RedisUtils {
@Autowired
@Qualifier("getRedisTemplate")
private RedisTemplate redisTemplate;
/**
* 設置鍵值
*
* @Param: [key, value]
* @return: boolean
* @Author: MaSiyi
* @Date: 2021/11/20
*/
public boolean set(final String key, Object value) {
boolean result = false;
try {
ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();
operations.set(key, value);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* 寫入緩存設置失效時間
*
* @param key
* @param value
* @return
*/
public boolean set(final String key, Object value, Long expireTime) {
boolean result = false;
try {
ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();
operations.set(key, value);
redisTemplate.expire(key, expireTime, TimeUnit.SECONDS);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
/**
* 批量刪除對應的value
*/
public void remove(final String... keys) {
for (String key : keys) {
remove(key);
}
}
/**
* 刪除對應的value
*/
public void remove(final String key) {
if (exists(key)) {
redisTemplate.delete(key);
}
}
/**
* 判斷緩存當中是否有對應的value
*
* @param key
* @return
*/
public boolean exists(final String key) {
return redisTemplate.hasKey(key);
}
/**
* 根據(jù)key,獲取到對應的value值
*
* @param key
* key-value對應的key
* @return 該key對應的值。
* 注: 若key不存在, 則返回null。
*
* @date 2020/3/8 16:27:41
*/
public String get(String key) {
return JSONObject.toJSONString(redisTemplate.opsForValue().get(key));
}
}第四步,配置yml
這是一個YAML格式的Spring Boot配置文件,配置了Redis數(shù)據(jù)庫的連接信息,包括:
- database: Redis數(shù)據(jù)庫的編號,默認為0。
- host: Redis服務器的IP地址。
- port: Redis服務器的端口號。
這些配置信息會被Spring Boot自動加載并注入到對應的Bean中,可以在代碼中使用這些Bean來連接和操作Redis數(shù)據(jù)庫。
spring:
redis:
database: 0
host: 127.0.0.1
port: 6379好了,就是這么的簡單,完整代碼請移至SpringBoot+Redis查看
以上就是SpringBoot集成Redis流程詳解的詳細內(nèi)容,更多關于SpringBoot集成Redis的資料請關注腳本之家其它相關文章!
相關文章
一文學透ApplicationContext繼承接口功能及與BeanFactory區(qū)別
這篇文章主要為大家介紹了ApplicationContext繼承接口功能及與BeanFactory區(qū)別示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04
Mybatis實現(xiàn)動態(tài)SQL編寫的示例詳解
這篇文章主要為大家詳細介紹了mybatis中的動態(tài)sql的使用以及緩存的相關知識,文中的示例代碼講解詳細,具有一定的學習價值,需要的可以參考一下2023-02-02
Java請求轉(zhuǎn)發(fā)和請求重定向區(qū)別詳解
這篇文章主要介紹了Java請求轉(zhuǎn)發(fā)和請求重定向區(qū)別詳解,請求轉(zhuǎn)發(fā)和請求重定向,但二者是完全不同的,所以我們今天就來盤他們的區(qū)別介紹,需要的朋友可以參考一下2022-07-07
詳解SpringBoot?統(tǒng)一后端返回格式的方法
今天我們來聊一聊在基于SpringBoot前后端分離開發(fā)模式下,如何友好的返回統(tǒng)一的標準格式以及如何優(yōu)雅的處理全局異常,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2022-05-05
Java Metrics系統(tǒng)性能監(jiān)控工具的使用詳解
Metrics是一個Java庫,可以對系統(tǒng)進行監(jiān)控,統(tǒng)計一些系統(tǒng)的性能指標。本文就來和大家詳細聊聊這個工具的具體使用,希望對大家有所幫助2022-11-11

