Я занимаюсь разработкой веб-приложения Spring Boot, используя JPL-интерфейс SWI-Prolog для вызова Prolog из Java.В режиме разработки все работает нормально.Когда я развертываю его в Docker, первый вызов на JPL через API работает нормально.Когда я снова пытаюсь вызвать JPL, происходит сбой JVM.
Я использую LD_PRELOAD , чтобы указать libswipl.so
SWI_HOME_DIR также устанавливается.
LD_LIBRARY_PATH установлен для указания на libjvm.so
Функция My Controller:
@PostMapping("/rules/testAPI/")
@Timed
public List<String> insertRule() {
String use_module_http = "use_module(library(http/http_open)).";
JPL.init();
Query q1 = new Query(use_module_http);
if (!q1.hasNext()) {
System.out.println("Failed to load HTTP Module");
} else {
System.out.println("Succeeded to load HTTP Module");
}
return null;
}
Консольный выход
1-й звонок
Succeeded to load HTTP Module
2-й звонок
#
# A fatal error has been detected by the Java Runtime Environment:
#
# SIGSEGV (0xb) at pc=0x00007f31705294b2, pid=16, tid=0x00007f30d2eee700
#
# JRE version: OpenJDK Runtime Environment (8.0_191-b12) (build 1.8.0_191-8u191-b12-2ubuntu0.18.04.1-b12)
# Java VM: OpenJDK 64-Bit Server VM (25.191-b12 mixed mode linux-amd64 compressed oops)
# Problematic frame:
# C [libswipl.so+0xb34b2] PL_thread_attach_engine+0xe2
#
# Core dump written. Default location: //core or core.16
#
# If you would like to submit a bug report, please visit:
# http://bugreport.java.com/bugreport/crash.jsp
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
Я загрузил файл журнала ошибок в pastebin. нажмите здесь
Кто-нибудь сталкивался с такой же проблемой?Есть ли решение по этому поводу?
Обратите внимание, что я также проверил это также с oracle-java-8, но возникает та же ошибка.
ОБНОВЛЕНИЕ:
@ Ответ CapelliC не сработал.