Jetcache开启FASTJSON2序列化

为什么要用Jetcache

JetCache是一个基于Java的缓存系统封装,它提供统一的API和注解来简化缓存的使用。JetCache比SpringCache更强大的注解,可以原生的支持TTL、两级缓存、分布式自动刷新,还提供了Cache接口用于手工缓存操作。

以前使用红薯大佬的j2cache,用起来挺舒服。但是由于j2cache很久没更新了,jedis驱动也比较旧,且不支持TTL。故而转为使用jetcache。

Jetcache现状

目前使用的版本是最新版2.7.4,按照官方的说法,最新版本已经不支持json序列化。但是由于某些数据监控和测试的需要,需要开启json以便在redis客户端能够很方便的观察数据。

有文章说未支持一级缓存的同步。从当前的版本看来,已经是实现了本地缓存的同步了,如果是redis作为二级的话,默认会使用LettuceBroadcastManager进行监听和推送。

需要配置地方

jetcache:remote:default:type: redis.lettucekeyConvertor: fastjson2 #other choose:fastjson/jacksonbroadcastChannel: ccframevalueEncoder: fastjson2 #other choose:kryo/kryo5/javavalueDecoder: fastjson2 #other choose:kryo/kryo5/java

只要配置好broadcastChannel即可,然后在生成cache时,指定syncLocal来监听变化:

	@PostConstructpublic void initCache(){QuickConfig qc = QuickConfig.newBuilder(entityClass.getSimpleName() + "Cache").expire(Duration.ofMinutes(30)).cacheType(CacheType.BOTH) // two level cache.syncLocal(true) // invalidate local cache in all jvm process after update.build();cache = cacheManager.getOrCreateCache(qc);}

此处配置了一个30分钟时长的缓存,发生变更时会广播。

扩展点

回到正题,讲一下如何进行扩展。github上有人扩展了jetcache-plus添加了jackson,需要的可以看看。这里只讲讲如何把jetcache自带的fastjson2给开启起来:

STEP1

按照官方的例子,继承DefaultEncoderParser添加一个新的EncoderParser

package org.ccframe.commons.helper;import com.alicp.jetcache.CacheConfigException;
import com.alicp.jetcache.anno.SerialPolicy;
import com.alicp.jetcache.anno.support.DefaultEncoderParser;
import com.alicp.jetcache.support.*;
import io.github.qy8502.jetcacheplus.JacksonValueDecoder;
import io.github.qy8502.jetcacheplus.JacksonValueEncoder;
import org.apache.lucene.search.highlight.DefaultEncoder;import java.net.URI;
import java.util.function.Function;public class JsonEncoderParser extends DefaultEncoderParser {public static final String SERIAL_POLICY_FASTJSON2 = "FASTJSON2";@Overridepublic Function<Object, byte[]> parseEncoder(String valueEncoder) {if (SERIAL_POLICY_FASTJSON2.equalsIgnoreCase(valueEncoder)) {return new Fastjson2ValueEncoder(true);} else {return super.parseEncoder(valueEncoder);}}@Overridepublic Function<byte[], Object> parseDecoder(String valueDecoder) {if (SERIAL_POLICY_FASTJSON2.equalsIgnoreCase(valueDecoder)) {Fastjson2ValueDecoder fastjson2ValueDecoder = new Fastjson2ValueDecoder(true);DecoderMap decoderMap = DecoderMap.defaultInstance();decoderMap.register(SerialPolicy.IDENTITY_NUMBER_FASTJSON2, Fastjson2ValueDecoder.INSTANCE);fastjson2ValueDecoder.setDecoderMap(decoderMap);return fastjson2ValueDecoder;} else {return super.parseDecoder(valueDecoder);}}}

至于为什么要用decoderMap.register,因为跟踪代码发现NPE了,翻了下源码参考下,做了个按ID缓存的cache,添加后正常了

STEP2

jetcache设计了一个扩展点,在生成ConfigProvider时,可以指定EncoderParser的bean

/*** Created on 2022/08/03.*/
package com.alicp.jetcache.anno.support;import com.alicp.jetcache.SimpleCacheManager;
import com.alicp.jetcache.support.StatInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;import java.util.function.Consumer;/*** used in non-spring-boot projects.** @author <a href="mailto:areyouok@gmail.com">huangli</a>*/
public class JetCacheBaseBeans {protected SpringConfigProvider createConfigProvider() {return new SpringConfigProvider();}@Bean(destroyMethod = "shutdown")public SpringConfigProvider springConfigProvider(@Autowired ApplicationContext applicationContext,@Autowired GlobalCacheConfig globalCacheConfig,@Autowired(required = false) EncoderParser encoderParser,@Autowired(required = false) KeyConvertorParser keyConvertorParser,@Autowired(required = false) Consumer<StatInfo> metricsCallback) {SpringConfigProvider cp = createConfigProvider();cp.setApplicationContext(applicationContext);cp.setGlobalCacheConfig(globalCacheConfig);if (encoderParser != null) {cp.setEncoderParser(encoderParser);}if (keyConvertorParser != null) {cp.setKeyConvertorParser(keyConvertorParser);}if (metricsCallback != null) {cp.setMetricsCallback(metricsCallback);}cp.init();return cp;}@Bean(name = "jcCacheManager",destroyMethod = "close")public SimpleCacheManager cacheManager(@Autowired ConfigProvider configProvider) {SimpleCacheManager cacheManager = new SimpleCacheManager();cacheManager.setCacheBuilderTemplate(configProvider.getCacheBuilderTemplate());return cacheManager;}
}

同理keyConvertorParser和metricsCallback也可以类似指定。

因此,只需在connfig类里添加一行代码即完成扩展

@EnableCreateCacheAnnotation            //缓存基本数据据类型的注解
@Configuration
public class RedisConfig{@Beanpublic EncoderParser encoderParser(){return new JsonEncoderParser();	// 支持json序列化}}

看下redis,已经是json格式了

收工~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/129143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android ConstraintLayout分组堆叠圆角ShapeableImageView

Android ConstraintLayout分组堆叠圆角ShapeableImageView <?xml version"1.0" encoding"utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:app"…

【网络协议】聊聊TCP如何做到可靠传输的

网络是不可靠的&#xff0c;所以在TCP协议中通过各种算法等机制保证数据传输的可靠性。生活中如何保证消息可靠传输的&#xff0c;那么就是采用一发一收的方式&#xff0c;但是这样其实效率并不高&#xff0c;所以通常采用的是累计确认或者累计应答。 如何实现一个靠谱的协议&…

chinese_llama_aplaca训练和代码分析

训练细节 ymcui/Chinese-LLaMA-Alpaca Wiki GitHub中文LLaMA&Alpaca大语言模型本地CPU/GPU训练部署 (Chinese LLaMA & Alpaca LLMs) - 训练细节 ymcui/Chinese-LLaMA-Alpaca Wikihttps://github.com/ymcui/Chinese-LLaMA-Alpaca/wiki/%E8%AE%AD%E7%BB%83%E7%BB%86%E…

DINO训练自己的数据集(swin transformer backbone)

源码&#xff1a;https://github.com/IDEA-Research/DINO 数据集&#xff1a;coco格式 COCODIR/├── train2017/├── val2017/└── annotations/├── instances_train2017.json└── instances_val2017.json 环境配置 1. 下载代码 git clone https://github.com/…

项目管理-科学管理基础-线性规划介绍及例题

项目管理中的线性规划是什么? 在项目管理中,线性规划是一种数学建模和优化技术,用于解决资源分配和进度规划的问题。线性规划的目标是在给定的资源限制下,找到最佳的资源分配方案,以满足项目的需求并优化特定的目标,如成本最小化或时间最短化。 线性规划的基本元素包括…

二叉树OJ题汇总

本专栏内容为&#xff1a;leetcode刷题专栏&#xff0c;记录了leetcode热门题目以及重难点题目的详细记录 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;Leetcode &#x1f69a;代码仓库&#xff1a;小小unicorn的代码仓库&#x1f69a; &…

香港金融科技周2023:AIGC重塑金融形态

10月31日&#xff0c;由香港财经事务及库务局与投资推广署主办的“香港金融科技周2023大湾区专场”盛大启幕。中国AI决策领先企业萨摩耶云科技集团创始人、董事长兼 CEO林建明受邀参加圆桌会议&#xff0c;与中国内地、香港以及全球金融科技行业顶尖人才、创新企业、监管机构和…

HNU程序设计 练习三-控制结构

1.台球游戏 【问题描述】 在本台球游戏中&#xff0c;包含多种颜色的球&#xff0c;其中&#xff1a;红球15只各1分、黄球1只2分、绿球1只3分、咖啡球1只4分、蓝球1只5分、粉球1只6分、黑球1只7分。 球的颜色表示为&#xff1a; r-红色球 y-黄色球 g-绿色球 c-咖啡色球 b-蓝色…

[论文精读]How Powerful are Graph Neural Networks?

论文原文&#xff1a;[1810.00826] How Powerful are Graph Neural Networks? (arxiv.org) 英文是纯手打的&#xff01;论文原文的summarizing and paraphrasing。可能会出现难以避免的拼写错误和语法错误&#xff0c;若有发现欢迎评论指正&#xff01;文章偏向于笔记&#x…

Zookeeper安装及配置

Zookeeper官网:Apache ZooKeeper 一般作为服务注册中心 无论在Windows下还是Linux下,Zookeeper的安装步骤是一样的,用的包也是同一个包 Window下安装及配置Zookeeper 下载后解压 linux安装 window及Linux安装及配置zookeeper_访问windos上的zookeeper-CSDN博客

react面试要点

# React面试知识点 ## React是什么&#xff1f;谈一谈你对react的理解 1 React是一个网页UI库 2 react的特点是 声明式 组件化 通用性 3 react优点&#xff1a; 简单&#xff0c;低耦合高内聚&#xff0c;由于虚拟dom概念&#xff0c;可以做到一次学习到处使用。 …

深度学习_4 数据训练之线性回归

训练数据 线性回归 基本原理 比如我们要买房&#xff0c;机器学习深度学习来预测房价。房价的影响因素有&#xff1a;卧室数量&#xff0c;卫生间数量&#xff0c;居住面积。此外&#xff0c;还需要加上偏差值来计算。我们要找到一个正确率高的计算方法来计算。 首先&#…

SOLIDWORKS参数化设计之部分打包 慧德敏学

参数化设计就是通过主参数来驱动整个模型的变化&#xff0c;类似于SOLIDWORKS的方程式中&#xff0c;使用全局变量来控制模型其它参数的变化&#xff0c;因此要做参数化就必须要确定好主参数以及变化逻辑。 我们之前介绍过SOLIDWORKS参数化设计软件-SolidKits.AutoWorks&#…

c语言作业2

7-1 判断成绩等级&#xff0c;输入3个科目的成绩&#xff0c;如果三门成绩都大于等于80则为优秀&#xff0c;输出等级为A&#xff1b;其余情况为一般&#xff0c;输出等级为B&#xff1b; 输入格式: 输入在一行中给出3个整数取值在[0,100]&#xff0c;其间以空格分隔。 输出格…

springboot 操作sql改变状态的时候,怎么防止并发操作带来的问题

springboot 操作sql改变状态的时候&#xff0c;怎么防止并发操作带来的问题 在Spring Boot中&#xff0c;防止并发操作带来的问题可以通过以下几种方式&#xff1a; 使用事务管理&#xff1a;Spring框架提供了事务管理功能&#xff0c;可以通过事务的隔离级别和传播行为来控制并…

【C++ 系列文章 -- 程序员考试 201811 下午场 C++ 专题 】

1.1 C 题目六 阅读下列说明和C代码&#xff0c;填写程序中的空&#xff08;1&#xff09; &#xff5e;&#xff08;5&#xff09;&#xff0c;将解答写入答题纸的对应栏内。 【说明】 以下C代码实现一个简单乐器系统&#xff0c;音乐类&#xff08;Music&#xff09;可以使用…

[Unity][VR]透视开发系列4-解决只看得到Passthrough但看不到Unity对象的问题

【视频资源】 视频讲解地址请关注我的B站。 专栏后期会有一些不公开的高阶实战内容或是更细节的指导内容。 B站地址: https://www.bilibili.com/video/BV1Zg4y1w7fZ/ 我还有一些免费和收费课程在网易云课堂(大徐VR课堂): https://study.163.com/provider/480000002282025/…

MongoDB——MongoDB删除系统自带的local数据库

一、MongoDB删除系统自带的local数据库 1.1、linux环境进入mongo客户端 输入 mongo 命令&#xff0c;进入命令行客户端 进入admin库&#xff0c;并登录&#xff0c;查看所有数据库 #进入admin库 use admin #并登录admin db.auth("username","password")…

前端工程化需要知道的一些知识

## 前端的概念 前端开发的产出是直接面向用户的 软技能&#xff1a;用户体验&#xff08;性能&#xff09; 编程技能&#xff1a; css: 综合实践能力、常见兼容hack html: 遵循w3c规范的语义化结…

Istio实战(十一)-Envoy 请求解析(下)

前言 Envoy 是一款面向 Service Mesh 的高性能网络代理服务。它与应用程序并行运行,通过以平台无关的方式提供通用功能来抽象网络。当基础架构中的所有服务流量都通过 Envoy 网格时,通过一致的可观测性,很容易地查看问题区域,调整整体性能。 Envoy也是istio的核心组件之一…