专注Java教育14年 全国咨询/投诉热线:400-8080-105
动力节点LOGO图
始于2009,口口相传的Java黄埔军校
首页 学习攻略 Java学习 Java基础学习:java缓存框架教程

Java基础学习:java缓存框架教程

更新时间:2020-04-29 12:37:07 来源:动力节点 浏览1941次

    Ehcache

    Ehcache是一个Java实现的开源分布式缓存框架,EhCache可以有效地减轻数据库的负载,可以让数据保存在不同服务器的内存中,在需要数据的时候可以快速存取。同时EhCache扩展非常简单,官方提供的Cache配置方式有多种。可以声明配置、xml中配置、程序里配置或者调用构造方法时传入不同的参数。

Java基础学习:java缓存框架教程

    Ehcache有如下特点

    存取速度非常快,性能很不错。

    支持应用多种缓存策略。

    分级缓存,用户可以指定哪些数据在硬盘中缓存,哪些数据在内存中缓存。

    可以通过RMI、可插入API等方式进行分布式缓存。

    具有缓存和缓存管理器的侦听接口。

    支持多缓存管理器实例,以及一个实例的多个缓存区域。

    默认提供Hibernate的缓存实现。

    0x02:Cacheonix

    Cacheonix同样也是一个基于Java的分布式集群缓存系统,它同样可以方便的实现分布式缓存的部署。Cacheonix作为一款开源的分布式缓存框架,可以满足中型企业规模的系统架构,对提升系统性能有非常棒的作用。

    Cacheonix有如下特点

    可靠的分布式Java缓存

    通过复制实现高可用性

    支持泛型的缓存API

    可与ORM框架集成

    使用数据分区实现负载均衡

    支持非多播网络

    高性能计算

    快速的本地Java缓存

    分布式锁机制

    0x03:JBossCache

    JBossCache是一款基于Java的事务处理缓存系统,它的目标是构建一个以Java框架为基础的集群解决方案,可以是服务器应用,也可以是JavaSE应用。

    JBossCache有如下特点

    集群高可用性

    JBossCache是可复制的Cache,状态总是和集群中的其它服务器同步保存。这使得任何存储在JBossCache的状态都能得到恢复,即使因服务器崩溃或重启。

    集群的cache消除了瓶颈

    JBossCache设计来缓存经常被访问到的Java对象,目的是动态地改进应用程序的性能。这使得移除数据访问瓶颈更容易,例如数据库连接。

    JBossCache实例很注意远程Cache的更新和同步。

    企业级

    JBossCache是高级的、企业级数据网格解决方案,提供了如事务处理、回收和Cache载入等特征。

    许可证

    JBossCache基于LGPL许可证,100%开源。

    0x04:OSCache

    OSCache是个一个广泛采用的高性能的J2EE缓存框架,OSCache能用于任何Java应用程序的普通的缓存解决方案。

    OSCache有如下特点

    缓存任何对象。可以不受限制的缓存部分jsp页面或HTTP请求,任何java对象都可以缓存。

    拥有全面的API。OSCacheAPI提供全面的程序来控制所有的OSCache特性。

    永久缓存。缓存能随意的写入硬盘,因此允许昂贵的创建(expensive-to-create)数据来保持缓存,甚至能让应用重启。

    支持集群。集群缓存数据能被单个的进行参数配置,不需要修改代码

    缓存记录的过期-。可以最大限度的控制缓存对象的过期,包括可插入式的刷新策略(如果默认性能不需要时)

    0x05:Memcached

    Memcached是一种基于内存的key-value存储,用来存储小块的任意数据(字符串、对象)。这些数据可以是数据库调用、API调用或者是页面渲染的结果。Memcached简洁而强大。它的简洁设计便于快速开发,减轻开发难度,解决了大数据量缓存的很多问题。它的API兼容大部分流行的开发语言。本质上,它是一个简洁的key-value存储系统。

    Memcached有如下特点

    基于libevent的事件处理

    memcached不互相通信的分布式

    协议简单

    内置内存存储方式

    0x06:J2Cache

    J2Cache是OSChina目前正在使用的两级缓存框架。第一级缓存使用Ehcache,第二级缓存使用Redis。由于大量的缓存读取会导致L2的网络成为整个系统的瓶颈,因此L1的目标是降低对L2的读取次数。该缓存框架主要用于集群环境中。单机也可使用,用于避免应用重启导致的Ehcache缓存数据丢失。

    文档

    https://www.oschina.net/doc/652

    另外J2Cache的代码仓库在码云上,可以去搜索一下。更详细介绍

    https://my.oschina.net/javayou/blog/1931381

    0x07:JetCache

    JetCache是阿里开源的缓存框架。JetCache是一个基于java的缓存系统封装,提供统一的API和注解简化缓存的使用。JetCache提供了比SpringCache更强大的注解,可以原生的支持TTL、两级缓存、分布式自动刷新,提供了Cache接口用于手工缓存操作。当前有四个实现,RedisCache、TairCache、CaffeineCache和一个简易的LinkedHashMapCache,要添加新的实现也是非常简单。

    JetCache有如下特点

    通过统一的API访问Cache系统

    通过注解实现声明式的方法缓存

    通过注解创建并配置Cache实例

    针对所有Cache实例和方法缓存的自动统计

    Key的生成策略和value的序列化策略是可以配置的

    分布式缓存自动刷新,分布式锁

    异步CacheAPI

    SpringBoot支持

Java基础学习:java缓存框架教程

 以上就是动力节点java培训机构的小编针对“Java基础学习:java缓存框架教程”的内容进行的回答,希望对大家有所帮助,如有疑问,请在线咨询,有专业老师随时为你服务。

提交申请后,顾问老师会电话与您沟通安排学习

免费课程推荐 >>
技术文档推荐 >>