redis簡介
redis作為一種非關係型資料庫,讀寫非常快,應用十分廣泛,它採用key-value的形式儲存資料,value常用的五大資料型別有string(字串),list(連結串列),set(集合),zset(有序集合)和hash(雜湊表)。
redis的特性決定了它的功能,它可以用來做以下這些事情!
- 排行榜,利用zset可以方便的實現排序功能
- 計數器,利用redis中原子性的自增操作,可以統計到閱讀量,點贊量等功能
- 簡單訊息佇列,list儲存結構,滿足先進先出的原則,可以使用lpush/rpop或rpush/lpop實現簡單訊息佇列
- session共享,分散式系統中,可以利用redis實現session共享。spring官方提供的分散式解決方案Spring Session就是利用redis 實現的。
Spring Boot對redis也實現自動化裝配,使用非常方便。
Spring Boot整合redis
1. 引入redis依賴
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
</dependency>
</dependencies>
2. 配置redis相關資訊
spring:
redis:
# redis庫
database: 0
# redis 伺服器地址
host: localhost
# redis 埠號
port: 6379
# redis 密碼
password:
# 連線超時時間(毫秒)
timeout: 1000
lettuce:
pool:
# 連線池最大連結數(負數表示沒有限制)
max-active: 8
# 連線池最大阻塞等待時間(負數表示沒有限制)
max-wait: -1
# 連線池最大空閒連線數
max-idle: 8
# 連線池最小空閒連線數
min-idle: 0
3. 操作redis
SpringBoot提供了兩個bean來操作redis,分別是RedisTemplate
和 StringRedisTemplate
,這兩者的主要區別如下。
RedisTemplate
使用的是JdkSerializationRedisSerializer
存入資料會將資料先序列化成位元組陣列然後在存入Redis資料庫。
StringRedisTemplate
使用的是StringRedisSerializer。
下面一起來看看效果:
@RestController
public class RedisDemo {
@Autowired
private RedisTemplate redisTemplate;
@Autowired
private StringRedisTemplate stringRedisTemplate;
@GetMapping("redisTmeplateData")
public void redisTemplateData(){
redisTemplate.opsForValue().set("name","Java旅途");
}
@GetMapping("stringRedisTemplateData")
public void stringRedisTemplateData(){
stringRedisTemplate.opsForValue().set("desc","堅持分享java技術棧");
}
}
第一個方法存入的資料如下圖:
第二個方法存入的資料如下圖:
由於RedisTemplate是序列化成位元組陣列儲存的,因此在redis客戶端的可讀性並不好。
自動快取
@Cacheable
可以標記在一個方法上,也可以標記在一個類上。當標記在一個方法上時表示該方法是支援快取的,當標記在一個類上時則表示該類所有的方法都是支援快取的。
如果新增了@Cacheable
註解,那麼方法被呼叫後,值會被存入redis,下次再呼叫的時候會直接從redis中取值返回。
@GetMapping("getStudent")
@Cacheable(value = "student:key")
public Student getStudent(){
log.info("我不是快取,我是new的物件!");
Student student = new Student("Java旅途",26);
return student;
}
記得要開啟快取,在啟動類加上@EnableCaching
註解
訪問上面的方法,如果不列印日誌,則是從快取中獲取的值。
封裝redisUtils
RedisTemplate提供了很多方法來操作redis,但是找起來比較費事,為了更好的操作redis,一般會封裝redisUtils來滿足業務開發。這裡簡單封裝幾個做個示例,如果開發中有需求可以自己封裝。
public class RedisUtils {
@Autowired
private RedisTemplate redisTemplate;
/**
* 普通存入
* @param key
* @param value
* @return
*/
public boolean set(String key,Object value){
try {
redisTemplate.opsForValue().set(key,value);
return true;
}catch (Exception e){
e.printStackTrace();
return false;
}
}
/**
* 普通獲取key
* @param key
* @return
*/
public Object get(String key){
return key == null ? null : redisTemplate.opsForValue().get(key);
}
/**
* 存入key,設定過期時長
* @param key
* @param value
* @param time
* @return
*/
public boolean set(String key,Object value,long time){
try {
if(time > 0){
redisTemplate.opsForValue().set(key,value,time, TimeUnit.SECONDS);
}else{
redisTemplate.opsForValue().set(key,value);
}
return true;
}catch (Exception e){
e.printStackTrace();
return false;
}
}
/**
* 判斷key是否存在
* @param key
* @return
*/
public boolean exists(String key){
try {
return redisTemplate.hasKey(key);
}catch (Exception e){
e.printStackTrace();
return false;
}
}
/**
* 刪除key
* @param key
*/
public void del(String key){
try {
if(key != null && key.length() > 0){
redisTemplate.delete(key);
}
}catch (Exception e){
e.printStackTrace();
}
}
}
此是spring-boot-route系列的第十二篇文章,這個系列的文章都比較簡單,主要目的就是為了幫助初次接觸Spring Boot 的同學有一個系統的認識。本文已收錄至我的github,歡迎各位小夥伴star
!
github:https://github.com/binzh303/spring-boot-route
點關注、不迷路
如果覺得文章不錯,歡迎關注、點贊、收藏,你們的支援是我創作的動力,感謝大家。
如果文章寫的有問題,請不要吝嗇,歡迎留言指出,我會及時核查修改。
如果你還想更加深入的瞭解我,可以微信搜尋「Java旅途」進行關注。回覆「1024」即可獲得學習視訊及精美電子書。每天7:30準時推送技術文章,讓你的上班路不在孤獨,而且每月還有送書活動,助你提升硬實力!