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 중국어 웹사이트의 기타 관련 기사를 참조하세요!