SpringBoot配置第三方专业缓存技术jetcache远程缓存方案和本地缓存方案

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: SpringBoot配置第三方专业缓存技术jetcache远程缓存方案和本地缓存方案

JetCache

是一个基于 Java 的分布式缓存解决方案,旨在提供高性能和可扩展性。它支持多种后端存储,如 Redis、Hazelcast、Tair 等,可以作为应用程序的缓存层,有效地提升数据访问性能和响应速度。

JetCache 的主要特点包括:

  1. 多种后端支持:可以根据需求选择不同的后端存储,如 Redis、Hazelcast 等,灵活适配不同的应用场景。
  2. 注解驱动:提供注解方式简化缓存的配置和使用,使得开发者能够轻松地在业务逻辑中加入缓存支持,减少手动编码工作。
  3. 二级缓存支持:支持二级缓存,允许在内存缓存和分布式缓存之间进行数据的存取,有效平衡性能和一致性要求。
  4. 缓存预热和失效策略:提供缓存预热功能,支持多种失效策略,如基于时间、基于数量、基于引用等。
  5. 高性能和可扩展性:设计上考虑了并发访问和数据一致性问题,以支持高并发和大规模应用场景。

JetCache 在企业级 Java 应用中广泛应用,帮助开发者通过简单的配置和注解,轻松地实现缓存管理,提升系统整体性能和响应速度。

jetcache远程缓存方案

我们之前的缓存控制台过于松散

JetCache 提供了多种远程缓存方案,主要基于不同的后端存储来实现分布式缓存的功能。以下是 JetCache 支持的一些主要远程缓存方案:

  1. Redis:Redis 是 JetCache 的主要后端之一,它提供了高性能的内存存储和持久化功能,适用于需要快速访问和高并发的场景。JetCache 可以通过 Redis 实现分布式缓存,支持多种缓存操作和数据结构。
  2. Hazelcast:Hazelcast 是一个开源的分布式内存数据网格,JetCache 可以利用 Hazelcast 来实现分布式缓存,支持分布式数据结构和集群管理,适合需要低延迟和高可用性的场景。
  3. Tair:Tair 是阿里云提供的分布式缓存服务,JetCache 支持通过 Tair 实现远程缓存,具有良好的可扩展性和高性能,适合在阿里云环境中构建应用。
  4. Caffeine:虽然 Caffeine 本身是一个本地缓存库,但 JetCache 也支持将其配置为远程缓存方案。在分布式应用场景中,可以通过 Caffeine 来实现基于内存的快速缓存,同时可以与其他远程缓存方案结合使用。

这些远程缓存方案使得开发者可以根据应用的需求选择合适的后端存储,利用 JetCache 提供的注解驱动和简化配置来管理分布式缓存,提升应用的性能和可扩展性。

本地方案

我们用的是ehcache

远程方案

我们使用的redis memcached

我们手动配置服务器IP地址和端口

但是我们还没有遇到

既能用远程缓存方案又能用本地缓存方案的

我们接下来要学习的jetcache就是

两种缓存方案都能用的

我们启动

我们在业务层接口的实现类里面没有用缓存技术

package com.example.demo.service.impl;
 
import com.example.demo.domain.SMSCode;
import com.example.demo.service.SMSCodeService;
import com.example.demo.utils.CodeUtils;
import net.rubyeye.xmemcached.MemcachedClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.CachePut;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;
 
@Service
public class SMSCodeServiceImpl implements SMSCodeService {
 
    @Autowired
    private CodeUtils codeUtils;
 
    @Override
    public String sendCodeToSMS(String tele) {
        String code=codeUtils.generator(tele);
        return code;
    }
 
    @Override
    public boolean checkCode(SMSCode smsCode) {
        String code=null;
        return smsCode.getCode().equals(code);
    }
 
}

我们把缓存都拿掉了

没有任何缓存

我们回忆之前的操作

记得好像是要加入各种坐标

<!--        jetcache缓存-->
        <dependency>
            <groupId>com.alicp.jetcache</groupId>
            <artifactId>jetcache-starter-redis</artifactId>
            <version>2.6.2</version>
        </dependency>

接着配置

远程存储 我们选择的是redis存储

jetcache:
  remote:
    default:
      type: redis
      host: localhost
      port: 6379
      poolConfig:
        maxTotal: 50

导入完毕

我们就可以进行使用了

启用使用注解的方式使用缓存

//开启缓存
@EnableCreateCacheAnnotation

这就代表我们可以用注解开启缓存

接下来我们来到业务层的实现类使用缓存

我们直接使用注解创建一个缓存

第一个参数是缓存名

第二个参数是过期时间 是设置缓存的过期时间

之前的过期时间是到处写 但是这里我们进行了一个统一

@CreateCache(name="jetCatch",expire = 3600,timeUnit = TimeUnit.SECONDS)
private Cache<String , String> jetCache;

package com.example.demo.service.impl;
 
import com.alicp.jetcache.Cache;
import com.alicp.jetcache.anno.CreateCache;
import com.example.demo.domain.SMSCode;
import com.example.demo.service.SMSCodeService;
import com.example.demo.utils.CodeUtils;
import net.rubyeye.xmemcached.MemcachedClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.cache.annotation.CachePut;
import org.springframework.cache.annotation.Cacheable;
import org.springframework.stereotype.Service;
 
import java.util.concurrent.TimeUnit;
 
@Service
public class SMSCodeServiceImpl implements SMSCodeService {
 
    @Autowired
    private CodeUtils codeUtils;
 
    //声明缓存空间
    @CreateCache(name="jetCatch",expire = 3600,timeUnit = TimeUnit.SECONDS)
    private Cache<String , String> jetCache;
 
    @Override
    public String sendCodeToSMS(String tele) {
        String code=codeUtils.generator(tele);
        //放入缓存
        jetCache.PUT(tele,code);
        return code;
    }
 
    @Override
    public boolean checkCode(SMSCode smsCode) {
        //取出缓存
        String code=jetCache.get(smsCode.getTele());
        return smsCode.getCode().equals(code);
    }
 
}

启动项目

启动成功

用postman进行测试

测试成功

恭喜

我们同样可以使用单独的配置

加上一个area属性即可

jetcache本地缓存方案

本地缓存方案与远程缓存方案一样

有默认设定还有自定义设置

但是我们在设置本地缓存的时候要设置键缓存

指定键转化为字符串的工具

查看maven工程的依赖

我们发现默认导入了一个依赖

fastjson

jetcache:
  local:
    default:
      type: linkedhashmap
      keyConvertor: fastjson

我们在业务层的实现类里面也要进行修改

//声明缓存空间
@CreateCache(name = "jetCache_",expire = 3600,timeUnit = TimeUnit.SECONDS)
private Cache<String , String> jetCache;

我们启动

查看信息

发现我们的配置的东西都有显示

设置缓存为本地缓存方案

//声明缓存空间
@CreateCache(name = "jetCache_",expire = 3600,timeUnit = TimeUnit.SECONDS,cacheType = CacheType.LOCAL)
private Cache<String , String> jetCache;

本地缓存和远程缓存时共存的

我们可以选择本地缓存的方案和远程的方案

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
6天前
|
存储 缓存 Java
在Spring Boot中使用缓存的技术解析
通过利用Spring Boot中的缓存支持,开发者可以轻松地实现高效和可扩展的缓存策略,进而提升应用的性能和用户体验。Spring Boot的声明式缓存抽象和对多种缓存技术的支持,使得集成和使用缓存变得前所未有的简单。无论是在开发新应用还是优化现有应用,合理地使用缓存都是提高性能的有效手段。
13 1
|
8天前
|
缓存 监控 负载均衡
在使用CDN时,如何配置缓存规则以优化性能
在使用CDN时,如何配置缓存规则以优化性能
消息中间件 缓存 监控
81 0
|
2月前
|
Java 数据库连接 数据库
告别繁琐 SQL!Hibernate 入门指南带你轻松玩转 ORM,解锁高效数据库操作新姿势
【8月更文挑战第31天】Hibernate 是一款流行的 Java 持久层框架,简化了对象关系映射(ORM)过程,使开发者能以面向对象的方式进行数据持久化操作而无需直接编写 SQL 语句。本文提供 Hibernate 入门指南,介绍核心概念及示例代码,涵盖依赖引入、配置文件设置、实体类定义、工具类构建及基本 CRUD 操作。通过学习,你将掌握使用 Hibernate 简化数据持久化的技巧,为实际项目应用打下基础。
66 0
|
2月前
|
Java 前端开发 Spring
技术融合新潮流!Vaadin携手Spring Boot、React、Angular,引领Web开发变革,你准备好了吗?
【8月更文挑战第31天】本文探讨了Vaadin与Spring Boot、React及Angular等主流技术栈的最佳融合实践。Vaadin作为现代Java Web框架,与其他技术栈结合能更好地满足复杂应用需求。文中通过示例代码展示了如何在Spring Boot项目中集成Vaadin,以及如何在Vaadin项目中使用React和Angular组件,充分发挥各技术栈的优势,提升开发效率和用户体验。开发者可根据具体需求选择合适的技术组合。
35 0
|
2月前
|
缓存 Java 数据库连接
Spring Boot 资源文件属性配置,紧跟技术热点,为你的应用注入灵动活力!
【8月更文挑战第29天】在Spring Boot开发中,资源文件属性配置至关重要,它让开发者能灵活定制应用行为而不改动代码,极大提升了可维护性和扩展性。Spring Boot支持多种配置文件类型,如`application.properties`和`application.yml`,分别位于项目的resources目录下。`.properties`文件采用键值对形式,而`yml`文件则具有更清晰的层次结构,适合复杂配置。此外,Spring Boot还支持占位符引用和其他外部来源的属性值,便于不同环境下覆盖默认配置。通过合理配置,应用能快速适应各种环境与需求变化。
34 0
|
2月前
|
XML Java 决策智能
拥抱智能决策新纪元!Spring Boot携手LiteFlow规则引擎,让复杂业务处理如丝般顺滑,引领技术潮流!
【8月更文挑战第29天】LiteFlow是一款专为Java应用设计的轻量级规则引擎,支持条件、循环、分支等多种规则类型,具有组件化设计和高度可扩展性。通过自定义规则和事件监听,它可以显著提升代码的可维护性和可重用性。本文将详细介绍如何在Spring Boot项目中整合LiteFlow,并通过实际案例演示其强大功能。主要步骤包括:添加依赖、配置参数、定义组件及流程,并通过API触发执行。借助LiteFlow,复杂业务逻辑处理变得更加灵活高效。
53 0
|
8天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的服装商城管理系统
基于Java+Springboot+Vue开发的服装商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的服装商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
31 2
基于Java+Springboot+Vue开发的服装商城管理系统
|
8天前
|
前端开发 JavaScript Java
SpringBoot项目部署打包好的React、Vue项目刷新报错404
本文讨论了在SpringBoot项目中部署React或Vue打包好的前端项目时,刷新页面导致404错误的问题,并提供了两种解决方案:一是在SpringBoot启动类中配置错误页面重定向到index.html,二是将前端路由改为hash模式以避免刷新问题。
49 1
|
6天前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的大学竞赛报名管理系统
基于Java+Springboot+Vue开发的大学竞赛报名管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的大学竞赛报名管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
20 3
基于Java+Springboot+Vue开发的大学竞赛报名管理系统
下一篇
无影云桌面