>Java >SIGSEGV 충돌 후 JVM을 빠르게 종료하는 방법은 무엇입니까?

SIGSEGV 충돌 후 JVM을 빠르게 종료하는 방법은 무엇입니까?

WBOY
WBOY앞으로
2024-02-09 19:09:091097검색

PHP 편집자 Xigua가 JVM에서 SIGSEGV 충돌이 발생하면 신속하게 종료할 수 있는 몇 가지 조치를 취할 수 있습니다. 먼저, JVM 매개변수 -XX:+CrashOnOutOfMemoryError를 설정하면 메모리가 오버플로될 때 JVM이 충돌하고 빠르게 종료되도록 할 수 있습니다. 둘째, Java의 예외 처리 메커니즘을 사용하여 SIGSEGV 예외를 포착하고 System.exit() 메서드를 호출하여 예외를 포착한 후 프로그램을 종료할 수 있습니다. 또한 JNI 인터페이스를 사용하여 운영 체제와 상호 작용하고 운영 체제에서 제공하는 종료 메서드를 호출하여 빠르게 종료할 수도 있습니다. 즉, JVM 매개변수를 적절하게 설정하고 적절한 예외 처리 메커니즘을 사용함으로써 JVM은 SIGSEGV 충돌 후 신속하게 종료될 수 있으며 프로그램의 안정성과 신뢰성을 향상시킬 수 있습니다.

질문 내용

텐서플로우 Java의 일부 문제로 인해 서비스 중 하나가 자주 충돌합니다. 우리는 그걸로 살아갈 수 있습니다(k8s는 많은 경우에 그것을 다시 시작할 것입니다). 문제는 jvm이 종료되는 데 몇 분이 걸린다는 것입니다. 네이티브 코드에서 sigsegv를 빠르게 종료하는 방법이 있습니까?

으아악

몇 분 후:

corrupted size vs. prev_size while consolidating
#
# a fatal error has been detected by the java runtime environment:
#
#  sigsegv (0xb) at pc=0x00007fe4f321a898, pid=1, tid=545
#
# jre version: openjdk runtime environment zulu21.28+85-ca (21.0+35) (build 21+35)
# java vm: openjdk 64-bit server vm zulu21.28+85-ca (21+35, mixed mode, sharing, tiered, compressed oops, compressed class ptrs, g1 gc, linux-amd64)
# problematic frame:
# c  [libc.so.6+0x28898]  abort+0x178
#
# core dump will be written. default location: /data/core
#
# an error report file with more information is saved as:
# /data/hs_err_pid1.log

해결 방법

다음 jvm 옵션을 추가하세요.

으아악

이렇게 하면 오류 보고서나 코어 덤프를 생성하지 않고 sigsegv에서 jvm이 즉시 종료됩니다. 여전히 치명적인 오류 메시지를 보려면 -xx:+suppressfatalerrormessage 替换为 -xx:errorlogtimeout=1를 바꾸세요.

이 jvm이 상당히 큰 힙(> 64GB)으로 실행되고 있고 너무 많은 메모리를 사용하는 프로세스의 경우 코어 덤프 파일을 작성하는 데 시간이 좀 걸리는 것 같습니다.

으아악

몇 분 동안 위 위치에서 코어 덤프 파일이 커지는 것을 볼 수 있습니다(이 이론을 확인하는 쉬운 방법입니다).

해결책은 코어 덤프 파일 생성을 비활성화하는 것입니다. 세부 사항은 특정 운영 체제에 따라 다릅니다(그러나 코어 덤프는 거의 모든 Unix 기반 운영 체제에서 비활성화될 수 있습니다). 또한 해당 특정 위치에 일부 파일 시스템 관련 병목 현상이 있어 코어 덤프가 예상보다 느리게 기록될 수 있습니다.

위 내용은 SIGSEGV 충돌 후 JVM을 빠르게 종료하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제