Ignite和SpringBoot整合时出现Failed to initialize system DB connection......MULTI_THREADED问题解决

本文主要是介绍Ignite和SpringBoot整合时出现Failed to initialize system DB connection......MULTI_THREADED问题解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求

计网实验需要使用SpringBoot+Ignite+JWT完成一个登录并存储用户权限的功能。

前期准备

在github上找了一个源码仓库:Spring Boot整合JWT实现用户认证。和我的需求十分接近,遂下载下来准备在其基础上二次开发。但是其由于是两年前的仓库,一些依赖包的版本到今天已经更新了不少。于是我准备将这些依赖包都更新到新版本,同时使用gradle而非原来的maven作为构建工具。

在问题出现时,和Ignite有关的代码如下:

@Configuration
public class IgniteCfg {/*** 初始化ignite节点信息* @return Ignite*/@Beanpublic Ignite igniteInstance(){// 配置一个节点的ConfigurationIgniteConfiguration cfg = new IgniteConfiguration();// 设置该节点名称cfg.setIgniteInstanceName("springDataNode");// 启用Peer类加载器cfg.setPeerClassLoadingEnabled(true);// 创建一个Cache的配置,名称为PersonCacheCacheConfiguration ccfg = new CacheConfiguration("PersonCache");// 设置这个Cache的键值对模型ccfg.setIndexedTypes(Long.class, Person.class);// 把这个Cache放入springDataNode这个Node中cfg.setCacheConfiguration(ccfg);// Ignite persistence configuration.// 创建一个持久化存储的设置DataStorageConfiguration storageCfg = new DataStorageConfiguration();// Enabling the persistence.// 是这个设置允许持久化存储storageCfg.getDefaultDataRegionConfiguration().setPersistenceEnabled(true);// 设置持久化存储路径storageCfg.setStoragePath("/opt/storage");// Applying settings.// 把这个Configuration放到springDataNode这个Node中cfg.setDataStorageConfiguration(storageCfg);// 启动这个节点Ignite ignite = Ignition.start(cfg);// 激活集群ignite.cluster().active(true);return ignite;}.......}

问题

我修改过的build.gradle配置文件如下。

plugins {id 'org.springframework.boot' version '2.3.0.RELEASE'id 'io.spring.dependency-management' version '1.0.9.RELEASE'id 'java'
}group = 'com.fwh'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '1.8'repositories {maven { url 'https://maven.aliyun.com/repository/public/' }maven { url 'https://maven.aliyun.com/repository/spring/'}maven{ url 'http://maven.aliyun.com/nexus/content/repositories/jcenter'}
}dependencies {implementation 'org.springframework.boot:spring-boot-starter-web'compile group: 'org.apache.ignite', name: 'ignite-core', version: '2.8.1'compile group: 'org.apache.ignite', name: 'ignite-spring', version: '2.8.1'compile group: 'org.apache.ignite', name: 'ignite-spring-data_2.2', version: '2.8.1'compile group: 'io.jsonwebtoken', name: 'jjwt', version: '0.9.1'compile group: 'com.h2database', name: 'h2', testImplementation('org.springframework.boot:spring-boot-starter-test') {exclude group: 'org.junit.vintage', module: 'junit-vintage-engine'}
}test {useJUnitPlatform()
}

按理说应该已经基本上添加了能够想到的所有依赖。但是运行项目,报错。
在这里插入图片描述
在这里插入图片描述

问题分析

首先对上面的igniteInstance编写单元测试,Ignite在不与Spring Boot产生关系的情况下能正常运行,可以说明确实是在两者配合时发生了bug.

首先就此问题询问一位已经完成的同学。
聊天记录-w40
关于h2的依赖问题,其实在网上有过广泛的讨论。在不久前的Ignite版本中,由于Ignite使用的h2依赖和Spring使用的h2依赖版本不一致,导致经常出现h2 property NESTED_JOINS doesn't exist问题。stackoverflow上的一个经典问答如下:
ignite won’t start with spring-boot 2.0.5 - h2 property NESTED_JOINS doesn’t exist

但是,这个问题我已经排查过了,在上面的build.gradle中明确声明了h2依赖。另外在找资料时我发现有人提到在最新的Ignite2.8版本中已经没有这个问题了。
在这里插入图片描述
该评论链接:ignite和springboot结合无法启动问题

这边陷入死路,在网上查找了几个小时的相关资料无果。回过头来重新审视自己的build.gradle和那位做完实验的同学的pom.xml,似乎只有一点不一样,他加入了连接MySql的依赖而我没有。于是我也尝试加入了mySql-connector-java的依赖,然后发现错误竟然奇迹般的消失了。

解决方法

在build.gradle中添加如下依赖:

compile group: 'mysql', name: 'mysql-connector-java', version: '8.0.20'

问题反思

这个解决方法非常匪夷所思!因为我在整个代码中并没有用到MySQL。在问题出现时,我的项目中和Ignite相关的代码只有igniteInstance那几行。甚至还没有用到持久化,为什么会需要MySQL的依赖呢?

一个猜想难道是由于Ignite内置的H2数据库或者说引擎本身不提供多线程的服务,导致了Caused by : ...: : Unsupported connection setting "MULTI_THREADED"。而声明了MySQL依赖后,Ignite改用了MySQL引擎,而MySQL可以提供相关的服务?

这个问题目前就只能先这样留作疑问了,如果我之后有机会会对Ignite深入学习的话,也许我会来补充完这篇博客。

其他

在解决问题的过程中,我尝试过将h2依赖更换为其他版本。但在我的机器上,除了1.4.197之外的版本都会直接在编译时报错。只有1.4.197可以编译成功(虽然其在运行时报出了上文中提到的错误)。

一个Ignite的中文文档网站:Apache Ignite技术服务网,点击导航栏里的java就可以跳转到文档页。

使用的github的作者的另一篇博客:在Spring Boot上部署ignite数据库的小例子

这篇关于Ignite和SpringBoot整合时出现Failed to initialize system DB connection......MULTI_THREADED问题解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/fwhdzh/article/details/106608761
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/219247

相关文章

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

一文详解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 将服务器上的压缩文件解压出来,