ignite分布式内存数据库在springboot中应用

2023-10-28 20:59

本文主要是介绍ignite分布式内存数据库在springboot中应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写了好多年了,求波点赞,收藏,关注,一键三连!!

官方回答的ignite资料网上很多很全,记录一下我认知的ignite,也是刚上手理解不是很全面,让我们主要来看看具体能解决什么问题。

ignite是一个分布式内存数据库,依赖于h2数据库。支持sql语法,支持完整的ACID。

每一个ingite服务即一个节点。在ignite中不区分master、slave,节点间互相平等,支持横向扩展,只要有足够多的节点,支持PB级数据存储。

主要说一下应用场景。

做缓存

ignite做缓存支持单个缓存管理。

数据支持内存、内存+原生持久化、内存+第三方DB持久化多种不同策略。作为缓存可用于关系型数据库的缓存层。

ignite提供3种缓存模式LOCAL本机模式、REPLICATED复制、PARTITIONED分片

应用场景

缓存预热

如果你的微服务集群有比如用户信息、部门信息等这类基础数据需要做缓存避免频繁调用接口查库,查多改少且小数据集。建议使用REPLICATED模式,他会在每个节点复制当前缓存的全量。当查询时无需在各个节点间查询。速度最快。但遇到写的场景,由于需要节点间同步,速度就会比较慢。

分布式缓存

一般的分布式缓存尽可能使用REPLICATED模式。他可以自定义缓存做操作也可以配置成DB数据的查询缓存。比如接口提供查询用户功能。使用ignite会将查询返回的用户对象,缓存到ignite中。下次查询时会自动查询缓存中数据而无需查库。只需要提前配置好。后续操作对开发透明。对于写数据,也是会自动添加到缓存中。提供缓存、db双写一致性。

关系型数据库的缓冲层

如果有批量增删改的场景,比如一次添加1000条记录。不可能前台一直转等待添加完成。可以使用ignite做缓冲,先将数据落入ingite,这时候接口返回添加完成。ignite会异步进行添加处理。并且可以配置异步处理线程、异步处理速率等。并且当集群部署时,(87,88,89)3个节点,ignite会将1000个记录按照一定规则(一般是均分)分发到3个节点进行添加操作。这里需要注意的是线程数配置,避免并发太高导致DB压力。

 

分布式锁

支持分布式锁,可以从ignite获取一个lock对象。该lock对象实现了JUC Lock接口

应用场景

接口的并发控制

比如支付系统,支付接口防止用户手抖点两次支付。需要对同一笔订单做并发控制。

 

消息、事件的发布/订阅

ignite提供了消息订阅发布功能,可发布某个主题的消息;比如节点A、B、C订阅了主题Notify。节点D订阅了主题Refund。当集群中任意一个节点发布了主题Notify的消息,ABC都会收到推送。而D不会收到推送。

应用场景

消息推送

比如支付系统支付完成后,订单系统需要修改订单状态为完成;推送服务需要发送微信消息;通知报表系统拉取新订单等等。

 

应用

做了个springboot 2.4.4 + ignite的小demo。实现了上述应用场景。需要的可以去资源自行下载。springboot 2.4.4 集成ignite

 

这篇关于ignite分布式内存数据库在springboot中应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/295902

相关文章

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2