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

相关文章

Java CompletableFuture如何实现超时功能

《JavaCompletableFuture如何实现超时功能》:本文主要介绍实现超时功能的基本思路以及CompletableFuture(之后简称CF)是如何通过代码实现超时功能的,需要的... 目录基本思路CompletableFuture 的实现1. 基本实现流程2. 静态条件分析3. 内存泄露 bug

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机

SpringBoot实现动态插拔的AOP的完整案例

《SpringBoot实现动态插拔的AOP的完整案例》在现代软件开发中,面向切面编程(AOP)是一种非常重要的技术,能够有效实现日志记录、安全控制、性能监控等横切关注点的分离,在传统的AOP实现中,切... 目录引言一、AOP 概述1.1 什么是 AOP1.2 AOP 的典型应用场景1.3 为什么需要动态插

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf