当前位置:首页 > 科技  > 软件

基于内存和 Redis 的两级 Java 缓存框架

来源: 责编: 时间:2024-02-29 14:36:07 268观看
导读环境:SpringBoot2.7.12 + j2cache2.8.51. 简介J2Cache 是 OSChina 目前正在使用的两级缓存框架(要求至少 Java 8)。第一级缓存使用内存(同时支持 Ehcache 2.x、Ehcache 3.x 和 Caffeine),第二级缓存使用 Redis(推荐)/Memc

环境:SpringBoot2.7.12 + j2cache2.8.5ewh28资讯网——每日最新资讯28at.com

1. 简介

J2Cache 是 OSChina 目前正在使用的两级缓存框架(要求至少 Java 8)。第一级缓存使用内存(同时支持 Ehcache 2.x、Ehcache 3.x 和 Caffeine),第二级缓存使用 Redis(推荐)/Memcached 。由于大量的缓存读取会导致 L2 的网络成为整个系统的瓶颈,因此 L1 的目标是降低对 L2 的读取次数。该缓存框架主要用于集群环境中。单机也可使用,用于避免应用重启导致的缓存冷启动后对后端业务的冲击。ewh28资讯网——每日最新资讯28at.com

数据读取

  • 读取顺序 -> L1 -> L2 -> DB
  • 数据更新
    从数据库中读取最新数据,依次更新 L1 -> L2 ,发送广播清除某个缓存信息
    接收到广播(手工清除缓存 & 一级缓存自动失效),从 L1 中清除指定的缓存信息

2. 实战案例

2.1 依赖管理

<dependency>  <groupId>net.oschina.j2cache</groupId>  <artifactId>j2cache-core</artifactId>  <version>2.8.5-release</version></dependency><dependency>  <groupId>net.oschina.j2cache</groupId>  <artifactId>j2cache-spring-boot2-starter</artifactId>  <version>2.8.0-release</version></dependency>

2.2 配置

redis:  # 地址, 多个地址使用‘,’逗号分割  hosts: localhost:6379  # 数据库索引  database: 11  # 密码  password: xxxooo  # 连接超时时间  timeout: 10s  # 连接池中的最小空闲连接  min-idle: 0  # 连接池中的最大空闲连接  max-idle: 8  # 连接池的最大数据库连接数  max-active: 8  # #连接池最大阻塞等待时间(使用负值表示没有限制)  max-wait: -1ms---j2cache:  openSpringCache: true  # 缓存中不存在时,运行缓存空对象  allowNullValues: true  redisClient: lettuce  l2CacheOpen: true  # 一级缓存使用caffeine  L1:    provider_class: caffeine  L2:    #使用springRedis替换二级缓存    provider_class: net.oschina.j2cache.cache.support.redis.SpringRedisProvider    config_section: redis  #使用springRedis进行广播通知缓失效  broadcast: net.oschina.j2cache.cache.support.redis.SpringRedisPubSubPolicy# 上面配置的一级缓存为caffeine, 那么这里对一级缓存的配置就必须以这个caffeine开头  caffeine:  # 配置一级,二级缓存的region,有效时间  region.xj: 10000, 120s---spring:  cache:    # 一级缓存使用caffeine    type: caffeine

2.3 核心操作类

@Servicepublic class UserService {  private final UserRepository userRepository ;  public UserService(UserRepository userRepository) {    this.userRepository = userRepository ;  }  @Transactional  public User save(User user) {    return this.userRepository.saveAndFlush(user) ;  }  @Cacheable(value = {"xj"}, key = "#id")  public User get(Long id) {    return this.userRepository.findById(id).orElse(null) ;  }  @Transactional  @CacheEvict(value = {"xj"}, key = "#id")  public void remove(Long id) {    this.userRepository.deleteById(id) ;  }}

以上是基本的操作,非常简单。ewh28资讯网——每日最新资讯28at.com

2.4 Controller接口

@RestController@RequestMapping("/users")public class UserController {  private final UserService userService ;  // 通过CacheChannel操作j2cache缓存方法  private final CacheChannel cacheChannel;    public UserController(UserService userService, CacheChannel cacheChannel) {    this.userService = userService ;    this.cacheChannel = cacheChannel ;   }    @GetMapping("/save")  public User save() {    User user = new User() ;    int num = new Random().nextInt(80);    user.setAge(num) ;    user.setName("姓名 - " + num) ;    user.setSex(num >= 50 ? "男" : "女") ;    return this.userService.save(user) ;  }    @GetMapping("/{id}")  public Object get(@PathVariable("id") Long id) {    // 从指定的region,指定的key获取数据,如果一级,二级缓存中不存在,则通过第三个参数Function手动获取    // 如果缓存中不存在时,同时配置了允许缓存空对象,则会缓存一个空对象到缓存中    return this.cacheChannel.get("xj", id.toString(), key -> this.userService.get(id) , true) ;  }    @GetMapping("/delete/{id}")  public Object remove(@PathVariable("id") Long id) {    this.userService.remove(id) ;    return "success" ;  }  }

2.5 测试

先通过save接口添加数据ewh28资讯网——每日最新资讯28at.com

图片图片ewh28资讯网——每日最新资讯28at.com

查询id=2的数据ewh28资讯网——每日最新资讯28at.com

图片图片ewh28资讯网——每日最新资讯28at.com

level=3 表示本次数据缓存中不存在,从数据库中获取的。刷新页面ewh28资讯网——每日最新资讯28at.com

图片图片ewh28资讯网——每日最新资讯28at.com

level=2,本次数据从二级缓存redis中获取。再次刷新页面ewh28资讯网——每日最新资讯28at.com

图片图片ewh28资讯网——每日最新资讯28at.com

level=1,本次数据从一级缓存caffeine中获取。后续再怎么刷新只要缓存没有过期都将从一级缓存中获取。ewh28资讯网——每日最新资讯28at.com

测试不存在的数据

图片图片ewh28资讯网——每日最新资讯28at.com

从数据库中查询不存在的数据。ewh28资讯网——每日最新资讯28at.com

图片图片ewh28资讯网——每日最新资讯28at.com

缓存了空对象。ewh28资讯网——每日最新资讯28at.com

测试删除数据

图片图片ewh28资讯网——每日最新资讯28at.com

缓存中会立即清除ewh28资讯网——每日最新资讯28at.com

图片图片ewh28资讯网——每日最新资讯28at.com

以上是本篇文章的全部内容,希望对你有帮助。ewh28资讯网——每日最新资讯28at.com

完毕!!!ewh28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-75295-0.html基于内存和 Redis 的两级 Java 缓存框架

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 没看过AQS源码,别说精通Java并发编程

下一篇: 了解HttpListener:用于创建基于HTTP协议的桌面&amp;Web应用程序

标签:
  • 热门焦点
  • 分布式系统中的CAP理论,面试必问,你理解了嘛?

    对于刚刚接触分布式系统的小伙伴们来说,一提起分布式系统,就感觉高大上,深不可测。而且看了很多书和视频还是一脸懵逼。这篇文章主要使用大白话的方式,带你理解一下分布式系统
  • 一文搞定Java NIO,以及各种奇葩流

    大家好,我是哪吒。很多朋友问我,如何才能学好IO流,对各种流的概念,云里雾里的,不求甚解。用到的时候,现百度,功能虽然实现了,但是为什么用这个?不知道。更别说效率问题了~下次再遇到,
  • Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein&ldquo;利用市场支配力量强迫服装厂商与之签订独家
  • 破圈是B站头上的紧箍咒

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之每年的暑期档都少不了瞄准追剧女孩们的古偶剧集,2021年有优酷的《山河令》,2022年有爱奇艺的《苍兰诀》,今年却轮到小破站抓住了追
  • 花7万退货退款无门:谁在纵容淘宝珠宝商家造假?

    来源:极点商业作者:杨铭在淘宝购买珠宝玉石后,因为保证金不够赔付,店铺关闭,退货退款难、维权无门的比比皆是。&ldquo;提供相关产品鉴定证书,支持全国复检,可以30天无理由退换货。&
  • 小米汽车电池信息疑似曝光:容量101kWh,支持800V高压快充

    7月14日消息,今日一名博主在社交媒体发布了一张疑似小米汽车电池信息的照片,显示该电池包正是宁德时代麒麟电池,容量为101kWh,电压为726.7V,可以预测小
  • 华为Mate 60系列用上可变灵动岛:正式版体验将会更出色

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 到手价3099元起!iQOO Neo8 Pro今日首销:安卓性能最强旗舰

    5月23日,iQOO如期举行了新品发布会,全新的iQOO Neo8系列也正式与大家见面,包含iQOO Neo8和iQOO Neo8 Pro两个版本,其中标准版搭载高通骁龙8+,而Pro版更
  • “买真退假” 这种“羊毛”不能薅

    □ 法治日报 记者 王春   □ 本报通讯员 胡佳丽  2020年初,还在上大学的小东加入了一个大学生兼职QQ群。群主&ldquo;七王&rdquo;在群里介绍一些刷单赚
Top