메뉴 건너뛰기

2023.02.15 17:02

자바 Thread dump

조회 수 58 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

 

Thread dump는 언제 해야 하는 가?


1. Java 어플리케이션이 Hang 상태가 될 때
Hang 상태는 Java 어플리케이션의 Thread들이 멈춰있는 상황입니다.
Shared Resource의 접근할 경우 다른 Thread가 사용할 수 없도록 Lock을 획득하며, 또한 이러한 Lock을 다른 Thread들이 이미 획득하고 있을 경우, Lock을 획득하기 위해 대기하게 됩니다.
Java에서의 Lock은 내부 Monitor를 통해 관리되기 때문에 Monitor 획득이 Lock 획득을 의미합니다.
이렇게 Lock을 획득하기 위해 대기하는 Thread들이 많아지고, 대기 시간이 길어지면 Hang 인것처럼 보여지게 됩니다.
Java 프로그램에서 Lock을 획득하기 위해서는 Synchronized구문을 이용하여 method 또는 block을 단위로 lock을 획득 할 수 있습니다.

2. Java 어플리케이션의 처리가 늦을 경우
Java 어플리케이션의 처리가 늦을 경우 어느 stack에서 지연되는지 확인하기 위해 활용할 수 있습니다.
Thread들이 sleep 단계에서 모두 대기하는 상태가 있을 수 있으며, 이러한 경우의 대표적인 경우가 SQL문 수행의 지연으로 DB에서의 데이터를 Socket read하기 위해 대기하는 상태라 할 수 있습니다.

3. Java 어플리케이션의 CPU 사용율이 높을 경우
Java 어플리케이션의 특정 Thread의 CPU 사용율이 높을 경우

 


어떻게 해야 하는 가?
일반적으로 3~5초 간격으로 3회 이상을 dump해서 분석 할 것을 권하고 있습니다.


Deadlock 의 대표적인 사례
- Database 에서 지연되어 리스너 객체, 세션 저장객체가 연속적으로 lock이 걸리고 이 lock를 해제 못하는 상태에 빠질 수 있습니다.
- log4j도  과도한 로깅으로 인한 지연될 수 있습니다.


비효율적인 CPU 사용 코드의 예

 

Hashtable aaa = ..... ;
 
Object value = null;
 
if(aaa.containsKey("zzz")) --> 비효율적인 구문
 
   value = aaa.get("zzz");   --> 비효율적인 구문
 
else
 
   return null;

위의 로직은 Hashtable의 내용을 두번씩 검색하게 되어 불필요한 CPU 자원을 사용하는 경우입니다.
아래와 같이 변경하여 수행한 결과 CPU 자원이1/3 줄어든 것을 확인 할 수 있었습니다.

 

Hashtable aaa = .....;
 
Object value = null;
 
return aaa.get("zzz");

 

비효율적인 System Call 사용의 예
WAS의 Hot-Deploy 기능을 사용함으로써 매 호출때 마다 ClassLoader가 변경 여부를 확인하기 위해 System call인 stat() 함수를 매번 수행하게 됩니다. 해당 모듈이 변경된 것이 확인 되면 모듈을 신규 반영 하는 작업을 수행하게 되며 즉시 반영이 이루어 집니다.
문제는 매 호출마다 변경 여부 확인을 위해 stat() 함수의 호출이 일어나는 것인데요. 이로 인해 SYSTEM CPU의 과부하가 발생할 수 있습니다. 일반적으로는 SYSTEM CPU가 약간 증가하고 성능이 약간 저하되는 수준이지만 특정 코드에 의해 과부하가 발생할 수 있습니다.
 

 

 

 

 

 

DEV

 


List of Articles
번호 제목 날짜 조회 수
151 자바 클래스와 메서드 2023.02.15 74
150 조건문과 제어문 2023.02.15 61
149 Singleton Pattern 과 DeadLock file 2023.02.15 74
» 자바 Thread dump file 2023.02.15 58
147 request header 로부터 접속 정보 확인 file 2023.02.15 74
146 자바 extends Thread, implements Runnable 차이 file 2023.02.15 77
145 자바 쓰레드 예제 및 사용 이유 알아보기 file 2023.02.15 72
144 자바 초기화는 무슨 뜻이고 왜 해야할까? file 2023.02.15 84
143 자바 extends, implements 차이점 알아보기 file 2023.02.15 75
142 자바 생성자란 무엇인가? file 2023.02.15 61
141 자바 필드, 멤버 변수, 전역 변수는 같은 말? file 2023.02.15 74
140 자바 클래스, 객체, 인스턴스 구분하기 file 2023.02.15 52
139 자바 객체화(인스턴스화) 알아보기 file 2023.02.15 69
138 자바 this, super 차이 알아보기 file 2023.02.15 72
137 자바 오버라이드, 오버로드 차이 알아보기 file 2023.02.15 70
136 자바 Statement PreparedStatement 차이 알아보기 file 2023.02.15 53
135 자바 메소드(Method)란 무엇인가? file 2023.02.15 78
134 자바에서 문자열 비교 시 == 가 아닌 equals를 써야하는 이유 file 2023.02.15 114
133 자바 배열 복사하는 방법 file 2023.02.15 61
132 자바 int 값 자리수 구하기 file 2023.02.15 74
Board Pagination Prev 1 2 3 4 5 6 7 8 Next
/ 8

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved