前言:此整合為非注解形式羡微,使用工具類進行自主數(shù)據(jù)控制
專有名詞解析:Jedis是Redis官方推薦的面向Java的操作Redis的客戶端排苍,而RedisTemplate是SpringDataRedis中對JedisApi的高度封裝
環(huán)境:
IDEA版本2017.3.1 x64
JDK1.8
SpringBoot2.1.1
總流程:
- pom導(dǎo)入Redis的依賴組件
- 全局配置文件配置Redis
- 編寫RedisTemplate工具類
- 編寫測試用例
pom導(dǎo)入Redis的依賴組件
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
全局配置文件配置Redis
spring:
redis:
host: yourIpAddress
password: yourPassword
port: 6379
jedis:
pool:
#最大連接數(shù)據(jù)庫連接數(shù),設(shè) 0 為沒有限制
max-active: 8
#最大等待連接中的數(shù)量,設(shè) 0 為沒有限制
max-idle: 8
#最大建立連接等待時間。如果超過此時間將接到異常苔严。設(shè)為-1表示無限制贡羔。
max-wait: -1ms
#最小等待連接中的數(shù)量,設(shè) 0 為沒有限制
min-idle: 0
編寫RedisTemplate工具類
/**
* @create 2018-12-10 23:10
* redis工具類
*/
@Component
public final class RedisUtil {
@Autowired
private RedisTemplate<Object, Object> redisTemplate;
/**
* 指定緩存失效時間
*
* @param key 鍵
* @param time 時間(秒)
* @return
*/
public boolean expire(String key, long time) {
try {
if (time > 0) {
redisTemplate.expire(key, time, TimeUnit.SECONDS);
}
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* 根據(jù)key 獲取過期時間
*
* @param key 鍵 不能為null
* @return 時間(秒) 返回0代表為永久有效
*/
public long getExpire(String key) {
return redisTemplate.getExpire(key, TimeUnit.SECONDS);
}
/**
* 判斷key是否存在
*
* @param key 鍵
* @return true 存在 false不存在
*/
public boolean hasKey(String key) {
try {
return redisTemplate.hasKey(key);
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* 刪除緩存
*
* @param key 可以傳一個值 或多個
*/
@SuppressWarnings("unchecked")
public void del(String... key) {
if (key != null && key.length > 0) {
if (key.length == 1) {
redisTemplate.delete(key[0]);
} else {
redisTemplate.delete(CollectionUtils.arrayToList(key));
}
}
}
// ============================String=============================
/**
* 普通緩存獲取
*
* @param key 鍵
* @return 值
*/
public Object get(String key) {
return key == null ? null : redisTemplate.opsForValue().get(key);
}
/**
* 普通緩存放入
*
* @param key 鍵
* @param value 值
* @return true成功 false失敗
*/
public boolean set(String key, Object value) {
try {
redisTemplate.opsForValue().set(key, value);
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* 普通緩存放入并設(shè)置時間
*
* @param key 鍵
* @param value 值
* @param time 時間(秒) time要大于0 如果time小于等于0 將設(shè)置無限期
* @return true成功 false 失敗
*/
public boolean set(String key, Object value, long time) {
try {
if (time > 0) {
redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
} else {
set(key, value);
}
return true;
} catch (Exception e) {
e.printStackTrace();
return false;
}
}
/**
* 遞增
*
* @param key 鍵
* @param delta 要增加幾(大于0)
* @return
*/
public long incr(String key, long delta) {
if (delta < 0) {
throw new RuntimeException("遞增因子必須大于0");
}
return redisTemplate.opsForValue().increment(key, delta);
}
/**
* 遞減
*
* @param key 鍵
* @param delta 要減少幾(小于0)
* @return
*/
public long decr(String key, long delta) {
if (delta < 0) {
throw new RuntimeException("遞減因子必須大于0");
}
return redisTemplate.opsForValue().increment(key, -delta);
}
}
編寫測試用例
@Autowired
RedisUtil redisUtil;
@Test
public void testRedis(){
Employee employee = employeeMapper.getEmpById(1);
//往redis中存入對象
redisUtil.set("emp",employee);
//從redis中取出對象
Employee emp = (Employee) redisUtil.get("emp");
System.out.println(emp);
}
查看緩存:
更多關(guān)于Redis的配置可參考官網(wǎng):https://redis.io/
更多Spring Boot整合可瀏覽此博客:malizhi.cn