欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解SpringBoot集成Redis來(lái)實(shí)現(xiàn)緩存技術(shù)方案

 更新時(shí)間:2017年06月28日 09:54:11   作者:FEINIK  
本篇文章主要介紹了詳解SpringBoot集成Redis來(lái)實(shí)現(xiàn)緩存技術(shù)方案,具有一定的參考價(jià)值,有興趣的可以了解一下

概述

在我們的日常項(xiàng)目開發(fā)過(guò)程中緩存是無(wú)處不在的,因?yàn)樗梢詷O大的提高系統(tǒng)的訪問(wèn)速度,關(guān)于緩存的框架也種類繁多,今天主要介紹的是使用現(xiàn)在非常流行的NoSQL數(shù)據(jù)庫(kù)(Redis)來(lái)實(shí)現(xiàn)我們的緩存需求。

Redis簡(jiǎn)介

Redis 是一個(gè)開源(BSD許可)的,內(nèi)存中的數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)系統(tǒng),它可以用作數(shù)據(jù)庫(kù)、緩存和消息中間件,Redis 的優(yōu)勢(shì)包括它的速度、支持豐富的數(shù)據(jù)類型、操作原子性,以及它的通用性。

案例整合

本案例是在之前一篇SpringBoot + Mybatis + RESTful的基礎(chǔ)上來(lái)集成Redis的,具體完整案例代碼可以看這里:https://github.com/AIFEINIK/SpringBoot-Learn/tree/master/spring-boot-redis2,關(guān)于Redis如何安裝可自行g(shù)oogle。

1、在Maven pom.xml文件中加入Redis包

<!--redis-->
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-redis</artifactId>
  <version>${boot.version}</version>
</dependency>

2、SpringBoot配置文件中配置Redis連接(YAML方式配置)

spring:
  application:
    name: spring-boot-redis
  redis:
    host: 192.168.145.132
    port: 6379
    timeout: 20000
    cluster:
      nodes: 192.168.211.134:7000,192.168.211.134:7001,192.168.211.134:7002
      maxRedirects: 6
    pool:
      max-active: 8
      min-idle: 0
      max-idle: 8
      max-wait: -1

解釋:本配置采用Redis一主三從的的配置方式來(lái)提高緩存的吞吐量

3、Redis配置類

@Configuration
public class RedisConfig {

  @Bean
  public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory connectionFactory) {
   RedisTemplate<Object, Object> template = new RedisTemplate<>();
   template.setConnectionFactory(connectionFactory);

   //使用Jackson2JsonRedisSerializer來(lái)序列化和反序列化redis的value值
   Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer(Object.class);

   ObjectMapper mapper = new ObjectMapper();
   mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
   mapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
   serializer.setObjectMapper(mapper);

   template.setValueSerializer(serializer);
   //使用StringRedisSerializer來(lái)序列化和反序列化redis的key值
   template.setKeySerializer(new StringRedisSerializer());
   template.afterPropertiesSet();
   return template;
  }
}

解釋:SpringBoot提供了對(duì)Redis的自動(dòng)配置功能,在RedisAutoConfiguration中默認(rèn)為我們配置了JedisConnectionFactory(客戶端連接)、RedisTemplate以及StringRedisTemplate(數(shù)據(jù)操作模板),其中StringRedisTemplate模板只針對(duì)鍵值對(duì)都是字符型的數(shù)據(jù)進(jìn)行操作,本示例采用RedisTemplate作為數(shù)據(jù)操作模板,該模板默認(rèn)采用JdkSerializationRedisSerializer的二進(jìn)制數(shù)據(jù)序列化方式,為了方便演示本示例采用Jackson2JsonRedisSerializer來(lái)序列化和反序列化redis的value值,使用StringRedisSerializer來(lái)序列化和反序列化redis的key值。

4、Service層應(yīng)用緩存(注解方式)

@Service
public class PersonService {

  @Autowired
  private PersonRepo personRepo;

  /**
   * @Cacheable 應(yīng)用到讀取數(shù)據(jù)的方法上,先從緩存中讀取,如果沒有再?gòu)腄B獲取數(shù)據(jù),然后把數(shù)據(jù)添加到緩存中
  * unless 表示條件表達(dá)式成立的話不放入緩存
   * @param username
   * @return
   */
  @Cacheable(value = "user", key = "#root.targetClass + #username", unless = "#result eq null")
  public Person getPersonByName(String username) {
    Person person = personRepo.getPersonByName(username);
    return person;
  }

  /**
  * @CachePut 應(yīng)用到寫數(shù)據(jù)的方法上,如新增/修改方法,調(diào)用方法時(shí)會(huì)自動(dòng)把相應(yīng)的數(shù)據(jù)放入緩存
   * @param person
   * @return
   */
  @CachePut(value = "user", key = "#root.targetClass + #result.username", unless = "#person eq null")
  public Person savePerson(Person person) {
    return personRepo.savePerson(person);
  }

  /**
  * @CacheEvict 應(yīng)用到刪除數(shù)據(jù)的方法上,調(diào)用方法時(shí)會(huì)從緩存中刪除對(duì)應(yīng)key的數(shù)據(jù)
   * @param username
   * @return
   */
  @CacheEvict(value = "user", key = "#root.targetClass + #username", condition = "#result eq true")
  public boolean removePersonByName(String username) {
    return personRepo.removePersonByName(username) > 0;
  }

  public boolean isExistPersonName(Person person) {
    return personRepo.existPersonName(person) > 0;
  }
}

解釋:

1、這里的緩存key為簡(jiǎn)單的字符串組合,也可根據(jù)具體需要實(shí)現(xiàn)自定義的Key生成器,然后在注解中使用keyGenerator來(lái)引用。

2、Spring Cache提供了一些供我們使用的SpEL上下文數(shù)據(jù),通過(guò)#來(lái)引用,具體可查看Spring官網(wǎng):http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/#cache-spel-context

5、數(shù)據(jù)訪問(wèn)資源類

@Component
@Path("personMgr")
public class PersonMgrResource {

  @Autowired
  private PersonService personService;

  @GET
  @Path("getPersonByName")
  @Produces(MediaType.APPLICATION_JSON)
  public JsonResp getPersonByName(@QueryParam("username") String username) {
    Person person = personService.getPersonByName(username);
    return JsonResp.success(person);
  }

  @POST
  @Path("removePersonByName")
  @Produces(MediaType.APPLICATION_JSON)
  public JsonResp removePersonByName(@QueryParam("username") String username) {
    if (personService.removePersonByName(username)) {
      return JsonResp.success();
    }
    return JsonResp.fail("系統(tǒng)錯(cuò)誤!");
  }

  @POST
  @Path("savePerson")
  @Produces(MediaType.APPLICATION_JSON)
  public JsonResp savePerson(Person person) {
    if (personService.isExistPersonName(person)) {
      return JsonResp.fail("用戶名已存在!");
    }
    if (personService.savePerson(person).getId() > 0) {
      return JsonResp.success();
    }
    return JsonResp.fail("系統(tǒng)錯(cuò)誤!");
  }
}


6、通過(guò)postman工具來(lái)測(cè)試緩存是否生效

第一次訪問(wèn)查找用戶:

第一次通過(guò)用戶名稱來(lái)查找用戶可以看到是從庫(kù)中查詢的數(shù)據(jù),我們可以通過(guò)RedisClient工具來(lái)查看數(shù)據(jù)已放入了緩存

第二次查找用戶:發(fā)現(xiàn)服務(wù)端并未打印任何數(shù)據(jù)庫(kù)查詢?nèi)罩荆梢灾赖诙尾樵兪菑木彺嬷胁樵兊玫降臄?shù)據(jù)。

總結(jié)

本文介紹如何通過(guò)SpringBoot來(lái)一步步集成Redis緩存,關(guān)于Redis的使用它不僅可以用作緩存,還可以用來(lái)構(gòu)建隊(duì)列系統(tǒng),Pub/Sub實(shí)時(shí)消息系統(tǒng),分布式系統(tǒng)的的計(jì)數(shù)器應(yīng)用,關(guān)于Redis更多的介紹,請(qǐng)前往查閱官方文檔。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解 Java HashMap 實(shí)現(xiàn)原理

    詳解 Java HashMap 實(shí)現(xiàn)原理

    這篇文章主要介紹了詳解 Java HashMap 實(shí)現(xiàn)原理的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下
    2021-03-03
  • MySQL數(shù)據(jù)文件直接通過(guò)拷貝備份與恢復(fù)的操作方法

    MySQL數(shù)據(jù)文件直接通過(guò)拷貝備份與恢復(fù)的操作方法

    這篇文章主要介紹了MySQL數(shù)據(jù)文件直接通過(guò)拷貝備份與恢復(fù)的操作方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-09-09
  • java簡(jiǎn)單實(shí)現(xiàn)斗地主發(fā)牌功能

    java簡(jiǎn)單實(shí)現(xiàn)斗地主發(fā)牌功能

    這篇文章主要為大家詳細(xì)介紹了java簡(jiǎn)單實(shí)現(xiàn)斗地主發(fā)牌功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • mybatis多個(gè)接口參數(shù)的注解使用方式(@Param)

    mybatis多個(gè)接口參數(shù)的注解使用方式(@Param)

    這篇文章主要介紹了mybatis多個(gè)接口參數(shù)的注解使用方式(@Param),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • MyBatis 執(zhí)行動(dòng)態(tài) SQL語(yǔ)句詳解

    MyBatis 執(zhí)行動(dòng)態(tài) SQL語(yǔ)句詳解

    大家對(duì)mybatis執(zhí)行任意sql語(yǔ)句都了解,那么MyBatis執(zhí)行動(dòng)態(tài)SQL語(yǔ)句呢?下面腳本之家小編給大家解答下mybatis執(zhí)行動(dòng)態(tài)sql語(yǔ)句的方法,非常不錯(cuò),感興趣的朋友參考下吧
    2016-08-08
  • 一篇文章弄懂Mybatis中#和$的區(qū)別

    一篇文章弄懂Mybatis中#和$的區(qū)別

    mybatis為我們提供了兩種支持動(dòng)態(tài)sql的語(yǔ)法#{}以及${},兩者都是動(dòng)態(tài)的向sql語(yǔ)句中傳入需要的參數(shù),下面這篇文章主要給大家介紹了如何通過(guò)一篇文章弄懂Mybatis中#和$區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • Java CAS原子操作詳解

    Java CAS原子操作詳解

    在synchronized的優(yōu)化過(guò)程中我們看到大量使用了CAS操作,CAS全稱Compare And Set(或Compare And Swap),簡(jiǎn)單來(lái)說(shuō)CAS操作就是一個(gè)虛擬機(jī)實(shí)現(xiàn)的原子操作
    2023-02-02
  • Java?WorkBook對(duì)Excel的基本操作方法

    Java?WorkBook對(duì)Excel的基本操作方法

    這篇文章主要介紹了Java?WorkBook對(duì)Excel的基本操作方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • Spring boot整合log4j2過(guò)程解析

    Spring boot整合log4j2過(guò)程解析

    這篇文章主要介紹了Spring boot整合log4j2過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • 如何使用MybatisPlus的SQL注入器提升批量插入性能

    如何使用MybatisPlus的SQL注入器提升批量插入性能

    本文給大家介紹如何使用MybatisPlus的SQL注入器提升批量插入性能,以實(shí)戰(zhàn)視角講述如何利用該特性提升MybatisPlus?的批量插入性能,感興趣的朋友跟隨小編一起看看吧
    2024-05-05

最新評(píng)論