JVM cra sh на Centos7 - PullRequest
       91

JVM cra sh на Centos7

0 голосов
/ 22 января 2020

Я использую Jetty-сервер на centos7, и он продолжает падать с ошибкой ниже

 # A fatal error has been detected by the Java Runtime Environment:
    #
    #  SIGSEGV (0xb) at pc=0x00007fdd323ee698, pid=79411, tid=0x00007fd05bdfd700
    #
    # JRE version: OpenJDK Runtime Environment (8.0_222-b10) (build 1.8.0_222-8u222-b10-1~14.04-b10)
    # Java VM: OpenJDK 64-Bit Server VM (25.222-b10 mixed mode linux-amd64 )
    # Problematic frame:
    # V  [libjvm.so+0x653698]
    #
    # Failed to write core dump. Core dumps have been disabled. To enable core dumping, try "ulimit -c unlimited" before starting Java again
    #
    # If you would like to submit a bug report, please visit:
    #   http://bugreport.java.com/bugreport/crash.jsp
    #

    ---------------  T H R E A D  ---------------

    Current thread (0x00007fd044001800):  JavaThread "cron4j::scheduler[875ca3d006f7a65e29bf90fc0000016fc6274c4c6286cd54]::executor[875ca3d006f7a65e293583000000016fc678c0816e4418c5]" [_thread_in_vm, id=93353, stack(0x00007fd05bcfd000,0x00007fd05bdfe000)]

    siginfo: si_signo: 11 (SIGSEGV), si_code: 1 (SEGV_MAPERR), si_addr: 0x0000000000000000
Stack: [0x00007fd05bcfd000,0x00007fd05bdfe000],  sp=0x00007fd05bdfc4b0,  free space=1021k
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
V  [libjvm.so+0x653698]
C  [libbCacheService.so+0x2068c]  JNIEnv_::GetObjectClass(_jobject*)+0x2e
C  [libbCacheService.so+0x1f400]  Java_com_applictaion_test_CacheService_buildCache+0x111
j  com.application.test.CacheService.buildCache([Lcom/application/test/db/CacheJNI;)V+0

Тот же код отлично работает в Ubuntu. Тем не менее, он продолжает отказывать в Centos 7.

У меня есть

gcc --version
gcc (GCC) 9.2.0
java-1.8.0-openjdk-amd64 and jre1.8.0_65 same issue with both the JRE versions
Further more I use -XX:+UseParallelGC for GC.

Как можно видеть, проблема в среде JVM libjvm.so, а не в приложении. Кроме того, те же настройки и код на Ubuntu работают нормально, есть идеи, что происходит с Centos 7?

Спасибо

Raj

1 Ответ

1 голос
/ 22 января 2020

Как можно видеть, проблема в среде JVM libjvm.so, а не в приложении

Нет: проблема, скорее всего, связана с libbCacheService.so, а не libjvm.so , Я не знаю, каково происхождение libbCacheService.so, но, учитывая, что Google находит этот вопрос только при поиске, я подозреваю, что это ваше приложение.

Кроме того, та же настройка и код в Ubuntu работает нормально

Это довольно часто встречается: приложение, демонстрирующее неопределенное поведение, работает "отлично" в одной системе и вылетает в другой.

Ваш первый шаг должен быть сборка libbCacheService.so с отладочной информацией, включение дампов ядра и проверка из ядра, что любая функция libjvm.so вызывается из JNIEnv_::GetObjectClass(), вызывается с правильными аргументами.

PS выглядит (из si_addr) что libjvm.so разыменовывает нулевой указатель. Возможно, потому что вы передали ему нулевой указатель в качестве одного из параметров.

...