hibernate-没用的ehcache(二级缓存)
发布日期:2021-05-04 01:05:57 浏览次数:8 分类:技术文章

本文共 6983 字,大约阅读时间需要 23 分钟。

ehcache是如何缓存的

1. 为什么需要缓存

提高程序的性能

2. 什么样的数据需要缓存

很少被修改或根本不改的热数据热数据:已上架商品/已下架商品

业务场景比如:耗时较高的统计分析sql、电话账单查询sql等

3. ehcache是什么

Ehcache 是现在最流行的纯Java开源缓存框架,配置简单、结构清晰、功能强大

注1:本章介绍的是2.X版本,3.x的版本和2.x的版本API差异比较大

4. ehcache的特点

4.1 够快
Ehcache的发行有一段时长了,经过几年的努力和不计其数的性能测试,Ehcache终被设计于large, high concurrency systems.
4.2 够简单
开发者提供的接口非常简单明了,从Ehcache的搭建到运用运行仅仅需要的是你宝贵的几分钟。其实很多开发者都不知道自己用在用Ehcache,Ehcache被广泛的运用于其他的开源项目
4.3 够袖珍
关于这点的特性,官方给了一个很可爱的名字small foot print ,一般Ehcache的发布版本不会到2M,V 2.2.3 才 668KB。
4.4 够轻量
核心程序仅仅依赖slf4j这一个包,没有之一!
4.5 好扩展
Ehcache提供了对大数据的内存和硬盘的存储,最近版本允许多实例、保存对象高灵活性、提供LRU、LFU、FIFO淘汰算法,基础属性支持热配置、支持的插件多
4.6 监听器
缓存管理器监听器 (CacheManagerListener)和 缓存监听器(CacheEvenListener),做一些统计或数据一致性广播挺好用的
4.7 分布式缓存
从Ehcache 1.2开始,支持高性能的分布式缓存,兼具灵活性和扩展性

5. ehcache的使用

5.1 导入相关依赖
   
      
    
net.sf.ehcache
ehcache
2.10.0   

注释: 通过properties全局变量

2.10.0

${ehcache-version}
在这里插入图片描述

5.2 resources:ehcache.xml

在这里插入图片描述
注释: ehcache.xml源码:

   
   
     xsi:noNamespaceSchemaLocation="http://ehcache.org/ehcache.xsd"
    
 updateCheck="false">




  timeToIdleSeconds="0" timeToLiveSeconds="600" memoryStoreEvictionPolicy="LRU"/>
   overflowToDisk="false" diskPersistent="false" timeToIdleSeconds="0"
   timeToLiveSeconds="300" memoryStoreEvictionPolicy="LRU"/>

数据已过期

##编码

5.3 核心接口
CacheManager:缓存管理器  Cache:缓存对象,缓存管理器内可以放置若干cache,存放数据的实质,所有cache都实现了Ehcache接口  Element:单条缓存数据的组成单位

在这里插入图片描述
在这里插入图片描述
EhcacheUtil源码:

package com.zking.test.Util;import net.sf.ehcache.Cache;import net.sf.ehcache.CacheManager;import net.sf.ehcache.Element;import java.io.InputStream;public class EhcacheUtil {private static CacheManager cacheManager;//cache缓存manager管理器//执行一次static {
try {
InputStream is = EhcacheUtil.class.getResourceAsStream("/ehcache.xml");//去项目里面读取/ehcache.xml文件
cacheManager = CacheManager.create(is);
} catch (Exception e) {
throw new RuntimeException(e);
}}private EhcacheUtil() {}public static void put(String cacheName, Object key, Object value) {
Cache cache = cacheManager.getCache(cacheName);
if (null == cache) {
//以默认配置添加一个名叫cacheName的Cache
cacheManager.addCache(cacheName);
cache = cacheManager.getCache(cacheName);
}
//把要保存的key,value--new成一个Element如何让cache缓存对象保存到put里面
cache.put(new Element(key, value));}public static Object get(String cacheName, Object key) {
Cache cache = cacheManager.getCache(cacheName);
if (null == cache) {
return null;
}
//element包含两个部分一个key一个value
Element element = cache.get(key);
//如果element为空返回null不为空返回value
return null == element ? null : element.getValue();}public static void remove(String cacheName, Object key) {
Cache cache = cacheManager.getCache(cacheName);
if (null == cache) {
return;
}
cache.remove(key);}}

重点:
在这里插入图片描述

   
   
   
   
   
   
   
   
   
   ##timeToIdleSeconds:多少分钟刷新一次;timeToLiveSeconds:存活多少分钟;
5.4 缓存对象及其属性都要序列化
1)属性通常使用的:implements Comparable
   
      2)对象通常使用的:implements Serializable
   
ehcache流程图:

在这里插入图片描述

6. hibernate缓存

6.1 一级缓存
session

在这里插入图片描述
BookDAOTest源码:

package com.zking.test.Dao;import static org.junit.Assert.*;import org.junit.Test;import com.zking.test.Model.BookModel;import com.zking.test.Util.EhcacheUtil;public class BookDaoTest {private BookDao bookDAO = new BookDao();/** * 通过此案例,让大家体会缓存的一个好处 *  * @param bookId * @return */public BookModel findById(Integer bookId) {// 开启缓存功能
// 缓存找-->数据库找
BookModel b = (BookModel) EhcacheUtil.get("book", bookId);
if (null == b) {
BookModel book = new BookModel();
book.setBookId(bookId);
b = bookDAO.loat(book);
if (null != b) {
EhcacheUtil.put("book", b.getBookId(), b);
}
}
return b;}@Testpublic void test1() {
//第一次进来缓存为空去数据库查询出了结果
System.out.println("aaaaaaaaaaaaa");
BookModel b = findById(1);
System.out.println(b);
System.out.println("bbbbbbbbbbbbbb");
//缓存里已有数据不需要去数据库查询
BookModel b2 = findById(1);
System.out.println(b2);}@Testpublic void test2() {
//拿到系统的一个临时文件路径
System.out.println(System.getProperty("java.io.tmpdir"));}}
6.2 二级缓存
SessionFactory  可拔插式

7. hibernate(5.2.12.Final)中使用二级缓存步骤(ehcache)

7.1 导入ehcache相关依赖
   
    
  org.hibernate
  hibernate-ehcache
5.2.12.Final   
7.2 resources添加ehcache.xml
7.3 hibernate.cfg.xml中添加二级缓存相关配置
     
   
    true  
      
    
     true  
       
     
      org.hibernate.cache.ehcache.EhCacheRegionFactory
     
    
   
7.4 指定实体类开启二级缓存
     
     
     
   
    

 .......  

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

注1:查全部需要编写代码来开启二级缓存的
query.setCacheRegion("entity.Dict");//指定缓存策略,名字必须实体类的完整类名 query.setCacheable(true);//手动开启二级缓存

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

参考源码

BookDao源码:

package com.zking.test.Dao;import java.util.ArrayList;import java.util.List;import org.hibernate.Session;import org.hibernate.Transaction;import org.hibernate.query.Query;import com.zking.test.Model.BookModel;import com.zking.test.Util.SessionFactoryUtil;public class BookDao {
public BookModel loat(BookModel book) {
Session session = null;
Transaction transaction =null;
try {
session = SessionFactoryUtil.openSession();//创建会话
transaction = session.beginTransaction();//打开事务
BookModel b = session.get(BookModel.class, book.getBookId());
transaction.commit();
return b;
} catch (Exception e) {
if(null !=transaction) {
transaction.rollback();
}
throw new RuntimeException(e);
}finally {
SessionFactoryUtil.closeSession();
}}public List  list1() {
String hql = "select b from BookModel b";
List  list = new ArrayList ();
Session session = null;
Transaction transaction = null;
try {
session = SessionFactoryUtil.openSession();
transaction = session.beginTransaction();
Query query = session.createQuery(hql);
// 手动指定缓存策略(可选)
query.setCacheRegion("com.zking.test.Model.BookModel");// 指定缓存策略,名字必须实体类的完整类名
// 手动开启二级缓存
query.setCacheable(true);// 手动开启二级缓存
list = query.list();
transaction.commit();// 提交事务
return list;
} catch (Exception e) {
if (null != transaction) {
transaction.rollback();// 回滚事务
}
throw new RuntimeException(e);
} finally {
SessionFactoryUtil.closeSession();
}}}

BookDaoTest源码:
package com.zking.test.Dao;

import static org.junit.Assert.*;

import java.util.List;

import org.junit.Before;
import org.junit.Test;

import com.zking.test.Model.BookModel;

public class BookDaoTest {

private BookDao bookDAO = new BookDao();private BookModel book;@Beforepublic void before() {
book = new BookModel();}/** * 现在的用法 * 二级缓存 */@Testpublic void loat() {
book.setBookId(1);
BookModel b = bookDAO.loat(book);
System.out.println(b);
System.out.println("xxxxxxxxxxxxxxxxxxxx");
BookModel b2 = bookDAO.loat(book);
System.out.println(b2);}@Testpublic void list1() {
List  list1 = bookDAO.list1();
for (BookModel b : list1) {
System.out.println(b);
}
System.out.println("xxxxxxxxxxxxxxxxxxxxx");
List  list2 = bookDAO.list1();
for (BookModel b : list2) {
System.out.println(b);
}}}

转载地址:https://blog.csdn.net/weixin_45067120/article/details/105438853 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:spring开源框架基础案例入门
下一篇:如何使用BigDecimal(最好关于钱用)在java增加数据

发表评论

最新留言

感谢大佬
[***.90.177.211]2022年08月15日 09时28分56秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

最新文章