메뉴 건너뛰기

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 프로젝트 & 아파치 &톰켓 연동 ]1. 폴더 만들기 file 2016.08.18 3983
150 프로젝트 & 아파치 &톰켓 연동 ]2. 자바 설치 file 2016.08.18 4170
149 [자바(스프링&mybatis&jsp) 프로젝트 & 아파치 &톰켓 연동]3. 이클립스 설치 file 2016.08.18 3756
148 [자바(스프링&mybatis&jsp) 프로젝트 & 아파치 &톰켓 연동 ]9. 이클립스 압타나 플러그인 설치 file 2016.08.18 4012
147 [자바(스프링&mybatis&jsp) 프로젝트 & 아파치 &톰켓 연동 ]11. 이클립스 프로젝트 생성 file 2016.08.18 3972
146 [자바(스프링&mybatis&jsp) 프로젝트 & 아파치 &톰켓 연동 ] 이클립스 프로젝트 생성 순서04.jdbc 드라이버 설치 file 2016.08.18 4209
145 [자바(스프링&mybatis&jsp) 프로젝트 & 아파치 &톰켓 연동 ] 이클립스 프로젝트 생성 순서07.commons-collection 설치 file 2016.08.18 3845
144 [자바(스프링&mybatis&jsp) 프로젝트 & 아파치 &톰켓 연동 ] 이클립스 프로젝트 생성 순서08.commons-logging 설치 file 2016.08.18 4458
143 set get 파라미터 2016.08.18 3658
142 eclipse 콘솔(로그)에 디버그(Debug) 모드에서 실행된 쿼리문을 보여주자. - 전자정부프레임워크 오라클 file 2016.08.29 4172
141 eclipse 콘솔(로그)에 디버그(Debug) 모드에서 실행된 쿼리문을 보여주자. - 전자정부프레임워크 오라클 file 2016.08.29 6001
140 로그인 컴포넌트 설치시 뷰 생성 에러 해결방법 (ORA-01031: 권한이 불충분합니다) file 2016.08.29 3874
139 기존 프로젝트, Table, View 모두 다 삭제하기 file 2016.08.29 4608
138 회원가입 양식에서 (필수/옵션)필드 추가/제거하기 file 2016.08.29 5334
137 회원가입 양식에서 (필수/옵션)필드 추가/제거하기 file 2016.08.29 4471
136 No bean name '***Service' is defined 오류나는 이유 및 해결방법 file 2016.08.29 4561
135 새로 만든 모듈의 iBatis 쿼리를 새로운 xml 파일에 만들고 싶다면 이렇게 하자. file 2016.08.29 3655
134 새로 만든 모듈의 iBatis 쿼리를 새로운 xml 파일에 만들고 싶다면 이렇게 하자. file 2016.08.29 3773
133 배치관리 컴포넌트 생성 후 에러 날 때 해결방법 file 2016.08.29 4269
132 스프링(Spring)의 Validator 기능을 사용하다가 '정의되지 않음 또는 null 참조인 'type' 속성을 가져올 수 없습니다.'라는 오류를 만났을 때 해결방법 file 2016.08.29 5166
Board Pagination Prev 1 2 3 4 5 6 7 8 Next
/ 8

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved