Spring全家桶——SpringBoot2集成Redis緩存

Spring Boot Redis Cache

在此章雁刷,我們將SpringBoot2.x集成Redis Cache剑刑,Redis是一個開源的,基于內(nèi)存的數(shù)據(jù)結(jié)構(gòu)存儲,可以用作數(shù)據(jù)庫凌节、緩存和消息代理钦听,在本章僅講解緩存集成。

準備工作

當前項目工具及環(huán)境

  • 開發(fā)工具 IDEA 2018.3
  • 依賴管理 Gradle 5.0
  • JDK 1.8
  • Redis

現(xiàn)在去初始化一個Spring網(wǎng)站初始生成一個SpringBoot項目

Spring Boot Redis 項目生成

進入網(wǎng)站 https://start.spring.io/
我們現(xiàn)在使用SPRING INITIALIZR工具生成一個初始化項目倍奢,在這里我們初始了4個依賴包

image

點擊生成下載過來一個zip包朴上,解壓之后導(dǎo)入IDEA工具就可以了

項目導(dǎo)入開發(fā)環(huán)境

build.gradle文件和maven的pom.xml相似,可以構(gòu)建項目的依賴配置文件

在IDEA初始界面點擊OPEN -> 選擇文件 -> 找到.gradle文件 -> 選擇Open —> Open as Project

image
image
image

這里的gradle環(huán)境是本地的卒煞,很簡單安裝配置痪宰,gradle官網(wǎng)下載二進制包然后解壓,環(huán)境變量配置一下就可以使用了

Spring Boot Redis Cache Gradle Dependencies

上面我們已經(jīng)初始化了一個項目依賴文件build.gradle畔裕,我們也可以去手動修改然后添加或修改自己需要的依賴等

image

點擊上圖左上角停止下載衣撬,換成下面的國內(nèi)源之后在加載gradle

build.gradle
buildscript {
    ext {
        springBootVersion = '2.1.1.RELEASE'
    }
    repositories {
        maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
        mavenCentral()
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
    }
}

apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'org.springframework.boot'
apply plugin: 'io.spring.dependency-management'

group = 'com.example'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = 1.8

repositories {
    maven { url 'http://maven.aliyun.com/nexus/content/groups/public/' }
    mavenCentral()
}


dependencies {
    implementation('org.springframework.boot:spring-boot-starter-data-jpa')
    implementation('org.springframework.boot:spring-boot-starter-data-redis')
    implementation('org.springframework.boot:spring-boot-starter-web')
    runtimeOnly('com.h2database:h2')
    testImplementation('org.springframework.boot:spring-boot-starter-test')
}
image
定義一個實體對象

要將數(shù)據(jù)存到redis,我們需要定義一個實體來進行交互扮饶,并需要序列化實體對象

User.java

package com.example.rediscache.model;

import javax.persistence.*;
import java.io.Serializable;

@Entity
public class User implements Serializable {

    private static final long serialVersionUID = 1L;

    @Id
    @SequenceGenerator(name = "SEQ_GEN", sequenceName = "SEQ_USER", allocationSize = 1)
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "SEQ_GEN")
    private Long id;
    private String name;
    private long money;

    public User() {
    }

    public User(String name, long money) {
        this.name = name;
        this.money = money;
    }

    //省略Getter 和 Setter
   
    @Override
    public String toString() {
        return String.format("User{id=%d, name='%s', money=%d}", id, name, money);
    }
}
配置 Redis Cache

使用springboot的依賴我們已經(jīng)用gradle來完成具练,除此之外我們還要配置下:
application.yml

# Redis Config
spring:
  cache:
    type: redis
  redis:
    host: localhost
    port: 6379
    password: pass1234

基于JPA的簡潔數(shù)據(jù)操作

UserRepository.java

package com.example.rediscache.repository;

import com.example.rediscache.model.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;

@Repository
public interface UserRepository extends JpaRepository<User, Long>  { }

開啟緩存并初始化數(shù)據(jù)

在啟動類增加注解@EnableCaching開啟緩存
并實現(xiàn)CommandLineRunner接口來執(zhí)行啟動完成之后的任務(wù)
RedisCacheApplication.java

package com.example.rediscache;

import com.example.rediscache.model.User;
import com.example.rediscache.repository.UserRepository;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cache.annotation.EnableCaching;

//springboot啟動時執(zhí)行任務(wù)CommandLineRunner
@SpringBootApplication
//開啟緩存
@EnableCaching
public class RedisCacheApplication implements CommandLineRunner {

    private final UserRepository userRepository;

    private final Logger logger = LoggerFactory.getLogger(getClass());

    @Autowired
    public RedisCacheApplication(UserRepository userRepository) {
        this.userRepository = userRepository;
    }

    public static void main(String[] args) {
        SpringApplication.run(RedisCacheApplication.class, args);
    }

    @Override
    public void run(String... args) throws Exception {
        logger.info("開始初始化user ->user count ->{}",userRepository.count());
        User james = new User("James", 2000);
        User potter = new User("Potter", 4000);
        User dumbledore = new User("Dumbledore", 999999);

        userRepository.save(james);
        userRepository.save(potter);
        userRepository.save(dumbledore);
        logger.info("初始化完成 數(shù)據(jù)-> {}.", userRepository.findAll());
    }
}
控制層骨架

UserController.java


package com.example.rediscache.controller;

import com.example.rediscache.repository.UserRepository;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.web.bind.annotation.*;

@RestController
public class UserController {

    private final Logger logger = LoggerFactory.getLogger(getClass());

    private final UserRepository userRepository;

    @Autowired
    public UserController(UserRepository userRepository) {
        this.userRepository = userRepository;
    }
    
    //...dosomething
}

現(xiàn)在測試緩存

當我們數(shù)據(jù)庫查詢出來的值要放到緩存里,用@Cacheable注解

    @Cacheable(value = "users", key = "#userId", unless = "#result.money < 10000")
    @RequestMapping(value = "/{userId}", method = RequestMethod.GET)
    public Object getUser(@PathVariable Long userId) {
        logger.info("獲取user信息根據(jù)ID-> {}.", userId);
        return userRepository.findById(userId);
    }

我們訪問 localhost:8080/1 和 localhost:8080/3 分別兩次

image

發(fā)現(xiàn)id為3的就走了一次方法 說明緩存成功
id為1的走了兩次是因為 unless里條件成立就不會緩存到redis

更新緩存

每次當我們的數(shù)據(jù)庫的值要更改甜无,我們緩存的也要更改 扛点,我們可以使用 @CachePut 注解

   @CachePut(value = "users", key = "#user.id")
    @PutMapping("/update")
    public User updatePersonByID(@RequestBody User user) {
        userRepository.save(user);
        return user;
    }
image
刪除緩存

當我們的數(shù)據(jù)從數(shù)據(jù)庫刪除,我們也要從緩存進行刪除,我們可以使用 @CacheEvict 注解
allEntries 是否清空所有緩存內(nèi)容岂丘,缺省為 false占键,如果指定為 true,則方法調(diào)用后將立即清空所有緩存

    @CacheEvict(value = "users", allEntries=true)
    @DeleteMapping("/{id}")
    public void deleteUserByID(@PathVariable Long id) {
        logger.info("刪除用戶根據(jù)ID-> {}", id);
        userRepository.deleteById(id);
    }
image
image

在redis中查看已經(jīng)沒有了緩存

送上redis可視化工具
redis desktop manager for windows:
鏈接:https://pan.baidu.com/s/1tYwfM0sHLlDGDdQZc-26Sg 密碼:4ivg
redis desktop manager for mac:
鏈接:https://pan.baidu.com/s/1g9gxtLoAtm1IA0fA5Zs0qQ 密碼:aj0r

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末元潘,一起剝皮案震驚了整個濱河市畔乙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌翩概,老刑警劉巖牲距,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異钥庇,居然都是意外死亡牍鞠,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門评姨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來难述,“玉大人,你說我怎么就攤上這事吐句⌒埠螅” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵嗦枢,是天一觀的道長攀芯。 經(jīng)常有香客問我,道長文虏,這世上最難降的妖魔是什么侣诺? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任殖演,我火速辦了婚禮,結(jié)果婚禮上年鸳,老公的妹妹穿的比我還像新娘趴久。我一直安慰自己,他們只是感情好搔确,可當我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布彼棍。 她就那樣靜靜地躺著,像睡著了一般妥箕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上更舞,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天畦幢,我揣著相機與錄音,去河邊找鬼缆蝉。 笑死宇葱,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的刊头。 我是一名探鬼主播黍瞧,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼原杂!你這毒婦竟也來了印颤?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤穿肄,失蹤者是張志新(化名)和其女友劉穎年局,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體咸产,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡矢否,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了脑溢。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片僵朗。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖屑彻,靈堂內(nèi)的尸體忽然破棺而出验庙,到底是詐尸還是另有隱情,我是刑警寧澤社牲,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布壶谒,位于F島的核電站,受9級特大地震影響膳沽,放射性物質(zhì)發(fā)生泄漏汗菜。R本人自食惡果不足惜让禀,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望陨界。 院中可真熱鬧巡揍,春花似錦、人聲如沸菌瘪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽俏扩。三九已至糜工,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間录淡,已是汗流浹背捌木。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留嫉戚,地道東北人刨裆。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像彬檀,于是被迫代替她去往敵國和親帆啃。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,877評論 2 345

推薦閱讀更多精彩內(nèi)容