Java 덤프는 네트워크 문제, 메모리 오류로 인해 가상 머신이 예기치 않게 중단되거나 사용자가 모든 유형의 키 입력 조합을 시작할 때 실수로 생성되는 일부 Java 코어입니다. Java Dump는 애플리케이션의 소스 코드에 통합된 Java Dump API를 호출하거나 명령줄을 통해 -Xdump:java 옵션을 직접 제공하여 쉽게 생성할 수 있습니다. Java Dump는 애플리케이션이 예기치 않게 실행을 중지할 때 발생하는 중지의 근본 원인을 진단하고 문제 해결에 유용한 정보를 제공하여 최종 사용자에게 도움을 제공합니다.
무료 소프트웨어 개발 과정 시작
웹 개발, 프로그래밍 언어, 소프트웨어 테스팅 등
구문
Java 덤프의 필요성은 앞서 언급한 것처럼 문제의 근본 원인에 따라 달라지므로 Java 덤프에 대한 특정 구문은 없습니다. 따라서 이 구문 흐름은 사용자가 JVM에 필요한 요청을 보내는 것만으로 근본 원인을 진단하고 jcmd 도구를 사용하여 분석을 수행하려는 경우이며, 전송에 사용되는 런타임에 동일한 시스템을 사용해야 합니다. 이 요청은 기계와 Java 프로그램에 전달됩니다. 따라서 구문은 다음과 같이 정의됩니다.
jcmd <process_ id> GC.heap_dump <pathname_for_file>
전달된 매개변수는 :
Java 덤프의 워크플로는 네트워크 중단, 메모리 오류 등. 또한, Java 프로그램 실행을 방해하는 모든 형태의 오류는 Java 덤프를 사용하여 문제 해결 및 근본 원인 진단을 통해 저장할 수 있습니다. Java에서 어떤 덤프가 작동하는지에 따라 다음과 같은 몇 가지 시나리오가 있습니다.
Java 덤프 도구 및 기술을 사용하여 모든 시나리오와 근본 원인을 포착하는 다양한 방법이 있습니다. 이는 메모리 누수 관련 문제 및 메모리 최적화 문제를 해결하는 데 매우 유용합니다. 이들은 대부분 다음과 같은 도구와 기술을 사용하여 시각화하고 분석할 수 있는 hprof 파일의 바이너리 형식으로 저장됩니다.
이 예는 리소스에 대해 교착 상태를 수행하는 스레드를 보여 주며, 이제 리소스에 대한 잠금을 획득했으므로 명령줄 언급에 있는 명령을 사용하여 Java 덤프를 사용하여 리소스에 대한 교착 상태를 분석할 가능성이 있습니다.
public class Java_lock_Dump_Demo { public static void main(String[] args) throws InterruptedException { Object ob_a = new Object(); Object ob_b = new Object(); Object ob_c = new Object(); Thread Java_lock_Dump_DemoThread1 = new Thread (new Java_lock_Dump_Demo_Sync_Thread(ob_a, ob_b ), "Java_lock_Dump_DemoThread1"); Thread Java_lock_Dump_DemoThread2 = new Thread (new Java_lock_Dump_Demo_Sync_Thread(ob_b, ob_c ), "Java_lock_Dump_DemoThread2"); Thread Java_lock_Dump_DemoThread3 = new Thread (new Java_lock_Dump_Demo_Sync_Thread(ob_c, ob_a ), "Java_lock_Dump_DemoThread3"); Java_lock_Dump_DemoThread1.start(); Thread.sleep(3000); Java_lock_Dump_DemoThread2.start(); Thread.sleep(3000); Java_lock_Dump_DemoThread3.start(); } } class Java_lock_Dump_Demo_Sync_Thread implements Runnable { private Object ob_a; private Object ob_b; public Java_lock_Dump_Demo_Sync_Thread(Object ob_a, Object ob_b) { this.ob_a = ob_a; this.ob_b = ob_b; } @Override public void run() { String nm = Thread.currentThread().getName(); synchronized (ob_a) { System.out.println(nm + " acquire_the_lock_on_first_resource " + ob_a); try { Thread.sleep(10000); } catch (InterruptedException e) { e.printStackTrace(); } synchronized (ob_b) { System.out.println(nm + " acquire_the_lock_on_second_resource " + ob_b); } System.out.println(nm + " Release_the_lock_for_second_object " + ob_b); } System.out.println(nm + " Release_the_lock_for_first_object " + ob_a); System.out.println(nm + " Completed with the deadlock_test for acquiring the resource."); } }
출력:
위 컴파일된 코드의 덤프를 가져오는 방법은 다음 명령을 사용하여 수행할 수 있습니다.
Jcmd<Process_id> GC.heap_dump <file-path> jcmd 20528 GC.heap_dump C:\Users\adutta\eclipse-workspace\Matcher_Example\src
Java Dumps is considered a very interesting feature in java as It provides programmers and users with the ability to get out of the unwanted and unexpected situations at the time of halt in the running program as well as when the machine goes out of memory space. It also provides the user with detailed and proper content for the root cause or the troubleshooting issue.
위 내용은 자바 덤프의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!