首頁 > 軟體

Spring Boot範例程式碼整合Redis詳解

2022-06-29 14:02:35

Redis 簡介

Redis 是完全開源的,遵守 BSD 協定,是一個高效能的 key-value 資料庫。

Redis 與其他 key - value 快取產品有以下三個特點:

  • Redis支援資料的持久化,可以將記憶體中的資料儲存在磁碟中,重啟的時候可以再次載入進行使用。
  • Redis不僅僅支援簡單的key-value型別的資料,同時還提供list,set,zset,hash等資料結構的儲存。
  • Redis支援資料的備份,即master-slave模式的資料備份。

Redis 優勢

效能極高 – Redis能讀的速度是110000次/s,寫的速度是81000次/s 。

豐富的資料型別 – Redis支援二進位制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 資料型別操作。

原子 – Redis的所有操作都是原子性的,意思就是要麼成功執行要麼失敗完全不執行。單個操作是原子性的。

多個操作也支援事務,即原子性,通過MULTI和EXEC指令包起來。

豐富的特性 – Redis還支援 publish/subscribe, 通知, key 過期等等特性。

Redis與其他key-value儲存有什麼不同

Redis有著更為複雜的資料結構並且提供對他們的原子性操作,這是一個不同於其他資料庫的進化路徑。Redis的資料型別都是基於基本資料結構的同時對程式設計師透明,無需進行額外的抽象。

Redis執行在記憶體中但是可以持久化到磁碟,所以在對不同資料集進行高速讀寫時需要權衡記憶體,因為資料量不能大於硬體記憶體。在記憶體資料庫方面的另一個優點是,相比在磁碟上相同的複雜的資料結構,在記憶體中操作起來非常簡單,這樣Redis可以做很多內部複雜性很強的事情。同時,在磁碟格式方面他們是緊湊的以追加的方式產生的,因為他們並不需要進行隨機存取。

新增Redis依賴包

在專案的pom.xml中新增如下:

<!-- redis依賴包 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

設定Redis資料庫連線

在application.properties中設定redis資料庫連線資訊,如下:

#redis設定
#Redis伺服器地址
spring.redis.host=127.0.0.1
#Redis伺服器連線埠
spring.redis.port=6379
#Redis資料庫索引(預設為0)
spring.redis.database=0 
#連線池最大連線數(使用負值表示沒有限制)
spring.redis.jedis.pool.max-active=50
#連線池最大阻塞等待時間(使用負值表示沒有限制)
spring.redis.jedis.pool.max-wait=3000
#連線池中的最大空閒連線
spring.redis.jedis.pool.max-idle=20
#連線池中的最小空閒連線
spring.redis.jedis.pool.min-idle=2
#連線超時時間(毫秒)
spring.redis.timeout=5000

編寫Redis操作工具類

將RedisTemplate範例包裝成一個工具類,便於對redis進行資料操作。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import java.util.concurrent.TimeUnit;
@Component
public class RedisUtils {
  @Autowired
  private RedisTemplate redisTemplate;
  /**
  * 讀取快取
  *
  * @param key
  * @return
  */
  public Object get(final String key) {
    return redisTemplate.opsForValue().get(key);
 }
  /**
  * 寫入快取
  */
  public boolean set( String key, Object value) {
    boolean result = false;
    try {
      redisTemplate.opsForValue().set(key, value,1, TimeUnit.DAYS);
      result = true;
   } catch (Exception e) {
      e.printStackTrace();
   }
    return result;
 }
  /**
  * 更新快取
  */
  public boolean getAndSet(final String key, String value) {
    boolean result = false;
    try {
      redisTemplate.opsForValue().getAndSet(key, value);
      result = true;
   } catch (Exception e) {
         e.printStackTrace();
   }
    return result;
 }
  /**
  * 刪除快取
  */
  public boolean delete(final String key) {
    boolean result = false;
    try {
      redisTemplate.delete(key);
      result = true;
   } catch (Exception e) {
      e.printStackTrace();
   }
    return result;
 }
}

測試

寫一個測試用例類來完成對redis的整合

@RunWith(SpringRunner.class)
@SpringBootTest
class Springboot02MybatisApplicationTests {
  @Autowired
  private RedisUtils redisUtils;
  @Autowired
  private CommentMapper commentMapper;
  @Test
  public void setRedisData() {
   redisUtils.set("article_1",articleMapper.selectByPrimaryKey(1));
    System.out.println("success");
 }
  @Test
  public void getRedisData() {
    Article article = (Article) redisUtils.get("article_1");
    System.out.println(article);
 }

到此這篇關於Spring Boot範例程式碼整合Redis詳解的文章就介紹到這了,更多相關Spring Boot Redis內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com