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

詳解SpringBoot緩存的實(shí)例代碼(EhCache 2.x 篇)

 更新時(shí)間:2017年07月24日 11:50:46   作者:陽光早已褪色  
這篇文章主要介紹了詳解SpringBoot緩存的實(shí)例代碼(EhCache 2.x 篇),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本篇介紹了SpringBoot 緩存(EhCache 2.x 篇),分享給大家,具體如下:

SpringBoot 緩存

在 spring Boot中,通過@EnableCaching注解自動(dòng)化配置合適的緩存管理器(CacheManager),Spring Boot根據(jù)下面的順序去偵測(cè)緩存提供者:

  • Generic
  • JCache (JSR-107)
  • EhCache 2.x
  • Hazelcast
  • Infinispan
  • Redis
  • Guava
  • Simple

關(guān)于 Spring Boot 的緩存機(jī)制:

高速緩存抽象不提供實(shí)際存儲(chǔ),并且依賴于由org.springframework.cache.Cache和org.springframework.cache.CacheManager接口實(shí)現(xiàn)的抽象。 Spring Boot根據(jù)實(shí)現(xiàn)自動(dòng)配置合適的CacheManager,只要緩存支持通過@EnableCaching注釋啟用即可。

Spring Boot 配置 EhCache 2.x

官方文檔上對(duì)于注解緩存的介紹資料非常之少,往往需要我們自己去了解相應(yīng)的緩存提供者。我這里主要介紹的是 EhCache .

引入依賴

在pom.xml文件中引入以下依賴

   <!--開啟 cache 緩存-->
   <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-cache</artifactId>
   </dependency>
   <!-- ehcache 緩存 -->
   <dependency>
     <groupId>net.sf.ehcache</groupId>
     <artifactId>ehcache</artifactId>
   </dependency>

引入配置文件 ehcache.xml

resource文件夾下創(chuàng)建文件ehcache.xml,并進(jìn)行配置:

<?xml version="1.0" encoding="UTF-8"?>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd"
     updateCheck="false">
  <defaultCache
      eternal="false"
      maxElementsInMemory="1000"
      overflowToDisk="false"
      diskPersistent="false"
      timeToIdleSeconds="0"
      timeToLiveSeconds="600"
      memoryStoreEvictionPolicy="LRU" />

  <!-- 這里的 users 緩存空間是為了下面的 demo 做準(zhǔn)備 -->
  <cache
      name="users"
      eternal="false"
      maxElementsInMemory="100"
      overflowToDisk="false"
      diskPersistent="false"
      timeToIdleSeconds="0"
      timeToLiveSeconds="300"
      memoryStoreEvictionPolicy="LRU" />
</ehcache>

ehcache.xml 文件配置詳解

部分資料來源于網(wǎng)絡(luò)

  1. diskStore:為緩存路徑,ehcache分為內(nèi)存和磁盤兩級(jí),此屬性定義磁盤的緩存位置。
  2. defaultCache:默認(rèn)緩存策略,當(dāng)ehcache找不到定義的緩存時(shí),則使用這個(gè)緩存策略。只能定義一個(gè)。
  3. name:緩存名稱。
  4. maxElementsInMemory:緩存最大數(shù)目
  5. maxElementsOnDisk:硬盤最大緩存?zhèn)€數(shù)。
  6. eternal:對(duì)象是否永久有效,一但設(shè)置了,timeout將不起作用。
  7. overflowToDisk:是否保存到磁盤,當(dāng)系統(tǒng)當(dāng)機(jī)時(shí)
  8. timeToIdleSeconds:設(shè)置對(duì)象在失效前的允許閑置時(shí)間(單位:秒)。僅當(dāng)eternal=false對(duì)象不是永久有效時(shí)使用,可選屬性,默認(rèn)值是0,也就是可閑置時(shí)間無窮大。
  9. timeToLiveSeconds:設(shè)置對(duì)象在失效前允許存活時(shí)間(單位:秒)。最大時(shí)間介于創(chuàng)建時(shí)間和失效時(shí)間之間。僅當(dāng)eternal=false對(duì)象不是永久有效時(shí)使用,默認(rèn)是0.,也就是對(duì)象存活時(shí)間無窮大。
  10. diskPersistent:是否緩存虛擬機(jī)重啟期數(shù)據(jù) Whether the disk store persists between restarts of the Virtual Machine. The default value is false.diskSpoolBufferSizeMB:這個(gè)參數(shù)設(shè)置DiskStore(磁盤緩存)的緩存區(qū)大小。默認(rèn)是30MB。每個(gè)Cache都應(yīng)該有自己的一個(gè)緩沖區(qū)。
  11. diskExpiryThreadIntervalSeconds:磁盤失效線程運(yùn)行時(shí)間間隔,默認(rèn)是120秒。
  12. memoryStoreEvictionPolicy:當(dāng)達(dá)到maxElementsInMemory限制時(shí),Ehcache將會(huì)根據(jù)指定的策略去清理內(nèi)存。默認(rèn)策略是LRU(最近最少使用)。你可以設(shè)置為FIFO(先進(jìn)先出)或是LFU(較少使用)。
  13. clearOnFlush:內(nèi)存數(shù)量最大時(shí)是否清除。
  14. memoryStoreEvictionPolicy:可選策略有:LRU(最近最少使用,默認(rèn)策略)、FIFO(先進(jìn)先出)、LFU(最少訪問次數(shù))。

FIFO,first in first out,先進(jìn)先出。

LFU, Less Frequently Used,一直以來最少被使用的。如上面所講,緩存的元素有一個(gè)hit屬性,hit值最小的將會(huì)被清出緩存。

LRU,Least Recently Used,最近最少使用的,緩存的元素有一個(gè)時(shí)間戳,當(dāng)緩存容量滿了,而又需要騰出地方來緩存新的元素的時(shí)候,那么現(xiàn)有緩存元素中時(shí)間戳離當(dāng)前時(shí)間最遠(yuǎn)的元素將被清出緩存。

在主類加上啟動(dòng)注解

在 Spring Boot 主類加上開啟緩存的注解@EnableCaching。

demo : SpringBoot + EhCache

搭建 Spring Boot 工程

我搭建了一個(gè)普通的 SpringBoot 工程,配置了 Druid+MySQL。

并在數(shù)據(jù)庫中創(chuàng)建了 users 表,各字段如下:

字段名 屬性
id bigint
uuid varchar
name varchar
age int

用戶實(shí)體類

User.Java

public class User {

  private long id;
  private String uuid;
  private String name;
  private Integer age;

  //省略 get、set 及 toString 方法
}

用戶數(shù)據(jù)庫操作接口

UserDao.java

@Mapper
public interface UserDao{

  void delete(String uuid);

  User update(User user);

  User findByUuid(String uuid);

  int save(@Param("user") User user);
}

用戶操作Mapper文件

UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
    PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="qg.fangrui.boot.dao.UserDao">
  <!--目的:為Dao接口方法提供SQL語句-->

  <!--映射實(shí)體對(duì)象-->
  <resultMap id="UserResultMap" type="qg.fangrui.boot.model.User">
    <id property="id" column="id" />
    <result property="uuid" column="uuid" />
    <result property="name" column="name" />
    <result property="age" column="age" />
  </resultMap>


  <insert id="save">
    INSERT INTO users(name, age, uuid)
    VALUES (#{user.name}, #{user.age}, #{user.uuid})
  </insert>

  <select id="findByUuid" resultType="User">
    SELECT * FROM users WHERE uuid = #{uuid}
  </select>

  <delete id="delete">
    DELETE FROM users WHERE uuid = #{uuid}
  </delete>

</mapper>

用戶操作 service 層

一般情況下,我們?cè)赟ercive層進(jìn)行對(duì)緩存的操作。先介紹 Ehcache 在 Spring 中的注解:在支持 Spring Cache 的環(huán)境下,

  1. @Cacheable : Spring在每次執(zhí)行前都會(huì)檢查Cache中是否存在相同key的緩存元素,如果存在就不再執(zhí)行該方法,而是直接從緩存中獲取結(jié)果進(jìn)行返回,否則才會(huì)執(zhí)行并將返回結(jié)果存入指定的緩存中。
  2. @CacheEvict : 清除緩存。
  3. @CachePut : @CachePut也可以聲明一個(gè)方法支持緩存功能。使用@CachePut標(biāo)注的方法在執(zhí)行前不會(huì)去檢查緩存中是否存在之前執(zhí)行過的結(jié)果,而是每次都會(huì)執(zhí)行該方法,并將執(zhí)行結(jié)果以鍵值對(duì)的形式存入指定的緩存中。
  4. 這三個(gè)方法中都有兩個(gè)主要的屬性:value 指的是 ehcache.xml 中的緩存策略空間;key 指的是緩存的標(biāo)識(shí),同時(shí)可以用 # 來引用參數(shù)。

UserService.java

@Service
public class UserService {

  //這里的單引號(hào)不能少,否則會(huì)報(bào)錯(cuò),被識(shí)別是一個(gè)對(duì)象
  private static final String CACHE_KEY = "'user'";
  private static final String DEMO_CACHE_NAME = "users";

  @Autowired
  private UserDao userDao;

  //刪除用戶數(shù)據(jù)
  @CacheEvict(value = DEMO_CACHE_NAME,key = "'user_'+#uuid")//這是清除緩存
  public void delete(String uuid){
    userDao.delete(uuid);
  }

  //更新用戶數(shù)據(jù)
  @CachePut(value = DEMO_CACHE_NAME,key = "'user_'+#user.getUuid()")
  public User update(User user) throws CacheException{
    User user1 = userDao.findByUuid(user.getUuid());
    if (null == user1){
      throw new CacheException("Not Find");
    }
    user1.setAge(user.getAge());
    user1.setName(user.getName());
    return user1;
  }

  //查找用戶數(shù)據(jù)
  @Cacheable(value=DEMO_CACHE_NAME,key="'user_'+#uuid")
  public User findByUuid(String uuid){
    //若找不到緩存將打印出提示語句
    System.err.println("沒有走緩存!"+uuid);
    return userDao.findByUuid(uuid);
  }

  //保存用戶數(shù)據(jù)
  @CacheEvict(value=DEMO_CACHE_NAME,key=CACHE_KEY)
  public int save(User user){
    return userDao.save(user);
  }
}

Controller 類

最后我們創(chuàng)建一個(gè) Controller 來訪問我們的緩存。因?yàn)槲业?SpringBoot 處于 Debug 模式,會(huì)將所有的數(shù)據(jù)庫操作打印出來,這樣子緩存作用就可一目了然了。

EhcacheController.java

@RestController
public class EhcacheController {

  private static final Logger logger = LoggerFactory.getLogger(EhcacheController.class);

  @Autowired
  private UserService userService;

  @RequestMapping("/encache")
  public String EhcacheTest(){
    logger.debug("進(jìn)行Encache緩存測(cè)試");
    System.out.println("====生成第一個(gè)用戶====");
    User user1 = new User();
    //生成第一個(gè)用戶的唯一標(biāo)識(shí)符 UUID
    String u1_uuid = UUID.randomUUID().toString();
    //去掉 UUID 的 - 符號(hào)
    String uuid1 = u1_uuid.substring(0,8)+u1_uuid.substring(9,13)+u1_uuid.substring(14,18)+u1_uuid.substring(19,23)+u1_uuid.substring(24);
    user1.setName("張三");
    user1.setAge(18);
    user1.setUuid(uuid1);
    if (userService.save(user1) == 0){
      throw new JdbcException("用戶對(duì)象插入數(shù)據(jù)庫失敗");
    }

    //第一次查詢
    System.out.println(userService.findByUuid(user1.getUuid()));
    //通過緩存查詢
    System.out.println(userService.findByUuid(user1.getUuid()));

    System.out.println("====修改數(shù)據(jù)====");
    User user2 = new User();
    user2.setName("李四-update");
    user2.setAge(22);
    user2.setId(user1.getId());
    user2.setUuid(user1.getUuid());
    try {
      System.out.println(userService.update(user2));
    } catch (CacheException e){
      e.printStackTrace();
    }

    System.out.println(userService.findByUuid(user2.getUuid()));
    return "success";
  }
}

測(cè)試

啟動(dòng) SpringBoot 工程,訪問 http://localhost:8080/encache ,并查看控制臺(tái)打印信息:

由控制臺(tái),我們可以清楚到看到,第一次查詢用戶信息時(shí),工程將用戶信息存入緩存中;在第二次查詢時(shí),無需訪問數(shù)據(jù)庫直接從緩存中獲取用戶信息。

個(gè)人參考項(xiàng)目:

個(gè)人參考項(xiàng)目:https://github.com/FunriLy/springboot-study/tree/master/%E6%A1%88%E4%BE%8B9

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

相關(guān)文章

  • elasticsearch節(jié)點(diǎn)的transport請(qǐng)求發(fā)送處理分析

    elasticsearch節(jié)點(diǎn)的transport請(qǐng)求發(fā)送處理分析

    這篇文章主要為大家介紹了elasticsearch節(jié)點(diǎn)的transport請(qǐng)求發(fā)送處理分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • SpringBoot bean的多種加載方式示例詳解

    SpringBoot bean的多種加載方式示例詳解

    本文詳細(xì)介紹了在SpringBoot中加載Bean的多種方式,包括通過xml配置文件、注解定義、特殊方式如FactoryBean、@ImportResource、ApplicationContext以及使用@Import注解導(dǎo)入bean的方法,感興趣的朋友跟隨小編一起看看吧
    2024-10-10
  • Spring IOC和DI實(shí)現(xiàn)原理及實(shí)例解析

    Spring IOC和DI實(shí)現(xiàn)原理及實(shí)例解析

    這篇文章主要介紹了Spring IOC和DI實(shí)現(xiàn)原理及實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • SpringBoot實(shí)現(xiàn)自定義線程池的方法

    SpringBoot實(shí)現(xiàn)自定義線程池的方法

    這篇文章主要介紹了SpringBoot中的自定義線程池解析,實(shí)現(xiàn)自定義線程池重寫spring默認(rèn)線程池的方式使用的時(shí)候,只需要加@Async注解就可以,不用去聲明線程池類,需要的朋友可以參考下
    2023-11-11
  • Java設(shè)計(jì)模式中的橋接模式

    Java設(shè)計(jì)模式中的橋接模式

    這篇文章主要介紹了Java設(shè)計(jì)模式中的橋接模式,其是一種結(jié)構(gòu)型設(shè)計(jì)模式,是指將實(shí)現(xiàn)與抽象放在兩個(gè)不同的類層次中,使兩個(gè)層次可以獨(dú)立改變
    2022-07-07
  • java 線程池的實(shí)現(xiàn)原理、優(yōu)點(diǎn)與風(fēng)險(xiǎn)、以及4種線程池實(shí)現(xiàn)

    java 線程池的實(shí)現(xiàn)原理、優(yōu)點(diǎn)與風(fēng)險(xiǎn)、以及4種線程池實(shí)現(xiàn)

    這篇文章主要介紹了java 線程池的實(shí)現(xiàn)原理、優(yōu)點(diǎn)與風(fēng)險(xiǎn)、以及4種線程池實(shí)現(xiàn)包括了:配置線程池大小配置,線程池的實(shí)現(xiàn)原理等,需要的朋友可以參考下
    2023-02-02
  • java中hashCode方法與equals方法的用法總結(jié)

    java中hashCode方法與equals方法的用法總結(jié)

    總的來說,Java中的集合(Collection)有兩類,一類是List,再有一類是Set。前者集合內(nèi)的元素是有序的,元素可以重復(fù);后者元素?zé)o序,但元素不可重復(fù)
    2013-10-10
  • Java中FileOutputStream流的write方法

    Java中FileOutputStream流的write方法

    這篇文章主要為大家詳細(xì)介紹了Java中FileOutputStream流的write方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • Java 實(shí)現(xiàn)貪吃蛇游戲的示例

    Java 實(shí)現(xiàn)貪吃蛇游戲的示例

    這篇文章主要介紹了Java 如何實(shí)現(xiàn)貪吃蛇游戲,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下
    2021-03-03
  • Java的Jackson自定義序列化詳解

    Java的Jackson自定義序列化詳解

    這篇文章主要介紹了Java的Jackson自定義序列化詳解,對(duì)比序列化器,可以看到,使用@JsonValue注解已經(jīng)將Leader類的序列化方式改變了,進(jìn)而影響了Country類,再來執(zhí)行test7()測(cè)試反序列化,結(jié)果與之前是一致的,需要的朋友可以參考下
    2023-11-11

最新評(píng)論