記事でSpringBootにEhcacheを統合させる

1.事前設定

依存関係を追加します。

ここに画像の説明を挿入
検索からmavenまで、ehcache依存関係ライブラリーを見つけて、pom構成ファイルを追加します。

<dependency>
    <groupId>net.sf.ehcache</groupId>
    <artifactId>ehcache</artifactId>
    <version>2.10.0</version>
</dependency>

2、ehcache.xmlを追加

<ehcache>
    <diskStore path="java.io.tmpdir/ehcache"/>
    <!--
    name:缓存名称。
       maxElementsInMemory:缓存最大个数。
       eternal:对象是否永久有效,一但设置了,timeout将不起作用。
       timeToIdleSeconds:设置对象在失效前的允许闲置时间(单位:秒)。仅当eternal=false对象不是永久有效时使用,可选属性,默认值是0,也就是可闲置时间无穷大。
       timeToLiveSeconds:设置对象在失效前允许存活时间(单位:秒)。最大时间介于创建时间和失效时间之间。仅当eternal=false对象不是永久有效时使用,默认是0.,也就是对象存活时间无穷大。
       overflowToDisk:当内存中对象数量达到maxElementsInMemory时,Ehcache将会对象写到磁盘中。
       diskSpoolBufferSizeMB:这个参数设置DiskStore(磁盘缓存)的缓存区大小。默认是30MB。每个Cache都应该有自己的一个缓冲区。
       maxElementsOnDisk:硬盘最大缓存个数。
       diskPersistent:是否缓存虚拟机重启期数据 Whether the disk store persists between restarts of the Virtual Machine. The default value is false.
       diskExpiryThreadIntervalSeconds:磁盘失效线程运行时间间隔,默认是120秒。
       memoryStoreEvictionPolicy:当达到maxElementsInMemory限制时,Ehcache将会根据指定的策略去清理内存。默认策略是LRU(最近最少使用)。你可以设置为FIFO(先进先出)或是LFU(较少使用)。
       clearOnFlush:内存数量最大时是否清除。

    -->
    <defaultCache
            maxElementsInMemory="10000"
            eternal="false"
            timeToIdleSeconds="120"
            timeToLiveSeconds="120"
            overflowToDisk="false"
            diskPersistent="false"
            diskExpiryThreadIntervalSeconds="120"
    />
    <cache name="yolo_cache"
           timeToIdleSeconds="120"
           maxElementsInMemory="10000"
           eternal="false"
           overflowToDisk="true"
           diskPersistent="true"
           diskExpiryThreadIntervalSeconds="600"/>
</ehcache>

それをehcache.xmlという名前でない場合は、リソースディレクトリに配置し、application.propertiesでファイルを指定する必要があります。

spring.cache.ehcache.config=classpath:name.xml

ここではname="yolo_cache"、次に使用するキャッシュ名と一致している必要があります。

3、テスト使用

(1)キャッシュを開く

ここに画像の説明を挿入
(2)書き込みサービス、キャッシュクエリメソッド:

ここに画像の説明を挿入
(3)テスト使用:1回だけ呼び出され、2回目はキャッシュです

ここに画像の説明を挿入
残りの使用法は同じです:記事でSpring Cache統合Redisを取得する

もはや

おすすめ

転載: blog.csdn.net/nanhuaibeian/article/details/108489524