摘要: JetCache是由阿里巴巴开源的通用缓存访问框架,如果你对Spring Cache很熟悉的话,请一定花一点时间了解一下JetCache,它更好用。JetCache可以做类似Spring Cache的注解式缓存,支持TTL、多级缓存、分布式自动刷新,也提供类似JSR107规范的Cache API。
JetCache是由阿里巴巴开源的通用缓存访问框架,如果你对Spring Cache很熟悉的话,请一定花一点时间了解一下JetCache,它更好用。
JetCache提供的核心能力包括:
- 提供统一的,类似jsr-107风格的API访问Cache,并可通过注解创建并配置Cache实例
- 通过注解实现声明式的方法缓存,支持TTL和两级缓存
- 分布式缓存自动刷新,分布式锁 (2.2+)
- 支持异步Cache API
- Spring Boot支持
- Key的生成策略和Value的序列化策略是可以定制的
- 针对所有Cache实例和方法缓存的自动统计
我们直接看代码,最简单的使用场景是这样的:
public interface UserService { @Cached(expire = 3600, cacheType = CacheType.REMOTE) User getUserById(long userId); }
这和Spring Cache很像,不过@Cached注解原生支持了TTL(超时时间),cacheType有LOCAL/REMOTE/BOTH三种选择,
分别代表本地内存/远程Cache Server(例如Redis)/两级缓存,可根据情况选用,合理的使用LOCAL或BOTH类型可以降低Cache Server的压力以及我们提供的服务的响应时间。
再看个复杂点的例子:
public interface UserService { @Cached(name="userCache-", key="#userId", expire = 3600) User getUserById(long userId); @CacheUpdate(name="userCache-", key="#user.userId", value="#user") void updateUser(User user); @CacheInvalidate(name="userCache-", key="#userId") void deleteUser(long userId); }
第一个例子中我们没有指定key,JetCache会根据参数自动生成,这个例子我们指定了key,并且展示了缓存的更新和删除。
自动刷新是JetCache的大杀器:
public interface SummaryService{ @Cached(expire = 3600, cacheType = CacheType.REMOTE) @CacheRefresh(refresh = 1800, stopRefreshAfterLastAccess = 3600, timeUnit = TimeUnit.SECONDS) BigDecimal salesVolumeSummary(int timeId, long catagoryId); }
cacheType为REMOTE或者BOTH的时候,刷新行为是全局唯一的,也就是说,即使应用服务器是一个集群,也不会出现多个服务器同时去刷新一个key的情况。
一个key的刷新任务,自该key首次被访问后初始化,如果该key长时间不被访问,在stopRefreshAfterLastAccess指定的时间后,相关的刷新任务就会被自动移除,这样就避免了浪费资源去进行没有意义的刷新。
加在方法上的注解毕竟不能提供最灵活的控制,所以JetCache提供了Cache API,使用起来就像Map一样:
UserDO user = userCache.get(12345L); userCache.put(12345L, loadUserFromDataBase(12345L)); userCache.remove(12345L); userCache.computeIfAbsent(1234567L, (key) -> loadUserFromDataBase(1234567L));
实际上Cache API实现了jsr107规范Cache接口的部分方法,以后的大版本可能会完整实现。
Cache实例可以通过注解创建:
@CreateCache(expire = 100, cacheType = CacheType.BOTH, localLimit = 50) private Cache<Long, UserDO> userCache;
也可以通过和guava cache/caffeine类似的builder来创建:
GenericObjectPoolConfig pc = new GenericObjectPoolConfig(); pc.setMinIdle(2); pc.setMaxIdle(10); pc.setMaxTotal(10); JedisPool pool = new JedisPool(pc, "localhost", 6379); Cache<Long, UserDO> userCache = RedisCacheBuilder.createRedisCacheBuilder() .keyConvertor(FastjsonKeyConvertor.INSTANCE) .valueEncoder(JavaValueEncoder.INSTANCE) .valueDecoder(JavaValueDecoder.INSTANCE) .jedisPool(pool) .keyPrefix("userCache-") .expireAfterWrite(200, TimeUnit.SECONDS) .buildCache();
Cache接口支持异步:
CacheGetResult r = cache.GET(userId); CompletionStage<ResultData> future = r.future(); future.thenRun(() -> { if(r.isSuccess()){ System.out.println(r.getValue()); } });
可以实现不严格的分布式锁:
cache.tryLockAndRun("key", 60, TimeUnit.SECONDS, () -> heavyDatabaseOperation());
使用Cache API也可以做自动刷新哦:
@CreateCache @CacheRefresh(timeUnit = TimeUnit.MINUTES, refresh = 60) private Cache<String, Long> orderSumCache; @PostConstruct public void init(){ orderSumCache.config().setLoader(this::loadOrderSumFromDatabase); }
如果没有使用注解,用builder一样也可以做出自动刷新:
Cache<String, Long> orderSumCache = RedisCacheBuilder.createRedisCacheBuilder() ......省略 .refreshPolicy(RefreshPolicy.newPolicy(60, TimeUnit.SECONDS)) .loader(this::loadOrderSumFromDatabase) .buildCache();
当前支持的缓存系统包括以下4个,而且要支持一种新的缓存也是非常容易的:
- Caffeine(基于本地内存)
- LinkedHashMap(基于本地内存,JetCache自己实现的简易LRU缓存)
- Alibaba Tair(相关实现未在Github开源,在阿里内部Gitlab上可以找到)
- Redis
使用JetCache的系统需求:
- JDK:必须Java 8
- Spring Framework:4.0.8以上,如果不使用注解就不需要
- Spring Boot:1.1.9以上(可选)
更多文档可以在github的wiki上找到。
阅读更多干货好文,请关注扫描以下二维码:
相关推荐
阿里开源的缓存框架JetCache JetCache是阿里开源的缓存框架,提供统一的API和注解来简化缓存的使用。该框架提供了四个实现,分别是RedisCache、TairCache、CaffeineCache和LinkedHashMapCache。 JetCache支持TTL、...
JetCache是阿里巴巴开源的一款高性能、轻量级的分布式缓存框架,适用于微服务架构中的缓存场景。本文将详细介绍如何在SpringBoot项目中整合JetCache,并探讨其本地缓存和Redis缓存的使用,以及如何实现多缓存的并行...
JetCache 是阿里巴巴开源的项目之一,它在阿里巴巴内部经过大规模的生产环境验证,证明了其稳定性和高效性。对于使用阿里巴巴其他中间件(如 Dubbo、Seata)的企业来说,JetCache 可以很好地融入现有的技术栈,提供...
阿里巴巴开源的Canal框架就是针对这一问题提供的一种高效解决方案。 Canal是一个轻量级的数据同步工具,它能够实时捕获并传输MySQL数据库中的DML(数据操纵语言)事件,如INSERT、UPDATE和DELETE,从而实现数据库到...
Dubbo是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000 个服务提供3,000,000,000 次访问量支持。 Dubbo 也是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入...
阿里巴巴仓库的maven配置文件,链接国内仓库,下载速度快,只需要配置一下本地仓库地址;阿里巴巴仓库的maven配置文件,链接国内仓库,下载速度快,只需要配置一下本地仓库地址;
阿里巴巴开源大数据平台的发展历程可以分为三个主要阶段:基于Hadoop构建的第一代大数据平台、大数据上云及实时化演进、以及大数据进入云原生时代。 第一阶段:基于Hadoop构建第一代大数据平台(2009-2015) 在这一...
Druid为监控而生的数据库连接池,它是阿里巴巴开源平台上的一个项目。Druid是Java语言中最好的数据库连接池,Druid能够提供强大的监控和扩展功能.它可以替换DBCP和C3P0连接池。Druid提供了一个高效、功能强大、可...
Arthas(阿尔萨斯)是阿里巴巴开源的 Java 诊断工具,开始在淘宝内部孵化使用,后来成为阿里java项目必须使用的内部工具。2018年arthas成为ali开源项目,代码托管在github上。这是带给java系一大福音,项目深受...
阿里巴巴开发规范插件是一款针对开发者设计的工具,旨在提高代码质量和一致性,确保代码遵循阿里巴巴的编码标准。这个离线包,名为“p3c-master”,包含了一整套用于静态代码分析和检查的规则,适用于Java、...
为此,阿里巴巴引入了分布式服务框架,通过将服务拆分成多个独立的部分来提高系统的可伸缩性和可用性。此外,分布式数据库的应用也解决了传统单体数据库面临的性能瓶颈问题,确保了数据的一致性和可靠性。 #### ...
该开源项目是一个基于阿里巴巴生态的自动化工具,主要功能包括自动登录和私信聊天。通过分析提供的文件名"已完成-阿里旺旺自动发消息",我们可以推测这个工具专注于阿里旺旺平台的消息发送。以下是对相关知识点的...
安装完成后,你需要获取阿里巴巴的Checkstyle配置文件,这通常可以在阿里巴巴开源项目的GitHub仓库中找到,如Alibaba Java Coding Guidelines。 1. **配置Checkstyle**: - 在Eclipse中,你可以通过Window -> ...
结合阿里巴巴的其他开源项目,如Sentinel(流量控制)、Hystrix(断路器)、Dubbo(服务治理框架)等,Arthas可以为整个微服务架构提供全方位的诊断能力。 总之,Arthas作为一款强大的在线分析诊断工具,极大地提高...
阿里巴巴普惠体是一款由阿里巴巴集团设计并发布的开源字体,旨在为全球用户提供免费、全面的中文字体解决方案。这款字体覆盖了广泛的语言和字符集,包括简体中文、繁体中文、拉丁字母、希腊字母、西里尔字母以及日...
该项目是阿里巴巴开源的MNN多语言神经网络设计源码,包含3095个文件,涵盖C++、Python等多种编程语言,涉及源代码、配置文件、文档等多种类型。
本项目深入解析并应用了阿里巴巴开源的Java诊断工具Arthas的设计源码,涉及1228个文件,涵盖653个Java源文件、159个Markdown文档、151个PNG图片、74个Vue文件、28个XML文件、26个JPG图片、22个JavaScript文件、18个...
该项目深入剖析了阿里巴巴开源的Java诊断工具Arthas的设计源码,包含2000个文件,涵盖894个Markdown文件、596个Java源文件、151个PNG图像文件、129个JSON文件、68个Vue文件、27个XML文件、26个JPG文件、18个...
【Apache Dubbo】Apache Dubbo 是阿里巴巴开源的一款高性能、轻量级的Java RPC框架,它致力于简化服务调用,提供接口级别的远程方法调用能力,同时具备智能容错和负载均衡机制,使得服务间的通信更加稳定高效。...
该项目深入分析了基于阿里巴巴开源的Java诊断工具Arthas的设计源码,涵盖376个文件,其中Java源文件占主导地位,共248个。文件类型还包括Markdown文档、XML配置、Shell脚本、图片、批处理文件、JAR包、文本、...