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

相关文章

PyTorch核心方法之state_dict()、parameters()参数打印与应用案例

《PyTorch核心方法之state_dict()、parameters()参数打印与应用案例》PyTorch是一个流行的开源深度学习框架,提供了灵活且高效的方式来训练和部署神经网络,这篇文章主要介绍... 目录前言模型案例A. state_dict()方法验证B. parameters()C. 模型结构冻

springboot控制bean的创建顺序

《springboot控制bean的创建顺序》本文主要介绍了spring-boot控制bean的创建顺序,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录1、order注解(不一定有效)2、dependsOn注解(有效)3、提前将bean注册为Bea

Java中的ConcurrentBitSet使用小结

《Java中的ConcurrentBitSet使用小结》本文主要介绍了Java中的ConcurrentBitSet使用小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、核心澄清:Java标准库无内置ConcurrentBitSet二、推荐方案:Eclipse

java中的Supplier接口解析

《java中的Supplier接口解析》Java8引入的Supplier接口是一个无参数函数式接口,通过get()方法延迟计算结果,它适用于按需生成场景,下面就来介绍一下如何使用,感兴趣的可以了解一下... 目录1. 接口定义与核心方法2. 典型使用场景场景1:延迟初始化(Lazy Initializati

Java中ScopeValue的使用小结

《Java中ScopeValue的使用小结》Java21引入的ScopedValue是一种作用域内共享不可变数据的预览API,本文就来详细介绍一下Java中ScopeValue的使用小结,感兴趣的可以... 目录一、Java ScopedValue(作用域值)详解1. 定义与背景2. 核心特性3. 使用方法

spring中Interceptor的使用小结

《spring中Interceptor的使用小结》SpringInterceptor是SpringMVC提供的一种机制,用于在请求处理的不同阶段插入自定义逻辑,通过实现HandlerIntercept... 目录一、Interceptor 的核心概念二、Interceptor 的创建与配置三、拦截器的执行顺

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

Spring Boot 中 RestTemplate 的核心用法指南

《SpringBoot中RestTemplate的核心用法指南》本文详细介绍了RestTemplate的使用,包括基础用法、进阶配置技巧、实战案例以及最佳实践建议,通过一个腾讯地图路线规划的案... 目录一、环境准备二、基础用法全解析1. GET 请求的三种姿势2. POST 请求深度实践三、进阶配置技巧1

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

Spring Boot 处理带文件表单的方式汇总

《SpringBoot处理带文件表单的方式汇总》本文详细介绍了六种处理文件上传的方式,包括@RequestParam、@RequestPart、@ModelAttribute、@ModelAttr... 目录方式 1:@RequestParam接收文件后端代码前端代码特点方式 2:@RequestPart接