이번엔 윤종현님이 놀라움을 표현해주신 '데드락 스레드를 찾을 수 있는 함수!'에 대해 자세히 살펴보겠습니다.
돌려보니 정말로 잘 찾아냅니다.
오해로 뒤엉켜 사랑에서 빠져나오지 못하는 가슴 아픈 두 스레드를 검출해줍니다.
메서드 이름이 충분히 직관적이라 별다른 설명은 필요없지만 예제코드 89라인에서
interrupt()로 데드락을 빠져나와보려는 무의미한 시도를 해본 것처럼
결과적으로 검출해서 뭐하지? 하는 생각이 들지 않을 수 없습니다.
이에 method-doc 에는 이렇게 써있습니다.
This method is designed for troubleshooting use, but not for synchronization control. It might be an expensive operation.
그렇습니다. 데드락을 찾아서 뭔가 해결을 해줄 수 있다면야, MXBean 계열에 이녀석이 포함되어있지도 않았을 것입니다. 아무튼 synchronized 키워드의 blocking을 강제로 피하게 할 수 없다는 것은 여전히 슬픈 일입니다.
ReetrantLock.tryLock은 timeout을 받을 수 있고 interruptable 이므로 데드락 검출시 이를 해결해줄 수
있겠다는 생각을 하여 ReetrantLock을 사용하여 Deadlock2 예제를 만들어보았습니다.
와와 데드락 검출 후 해당 thread.interrupt()로 데드락을 붕괘시키는데 성공했습니다! ㅎㅎ
한가지 아쉬운 것은, 스레드가 데드락인지 검출할 수 있다면 pair로 찾거나 서로 엉킨 녀석들을 세트로 묶어 리턴해준다면 더 좋았지 않았을까 하는 생각이 듭니다.
데드락 특성상 한 놈만 포기해주면 나머지가 행복해질 수 있는거니 말입니다.
생각해보니, 데드락된 스레드들의 stack을 덤프해다 담당 프로그래머에게 던져주며 "야 " 하면 되겠군요..
Comments
5 thoughts shared
Continue Reading
Discover more thoughts and insights
이전 게시판 복구
Essay 게시판과 Tip\&Tech 게시판을 복구했습니다. 원래 Database는 날라가지 않은 상태였고, 게시판이 없어서 간단히 조회만 가능하도록 만들어두었습니다. Apache 로그를 보면 essay나
내가 뽑은 연금술사 명대사
좋은 친구 윤재가 빌려주었고, 세상에 하나뿐인 사랑하는 애인님이 이 책을 읽도록 trigger 해준 '연금술사' 라는 책을 보면서, 파울로 코엘료 팬이 되었다. 명대사라고 생각한 부분을 옮겨본다. 별것 아닌것처럼
요새 나의 패턴
할 일이 많다. 놀 일도 많다. 하고 싶은 문화생활도 많다. 만나고 싶은 사람들도 있다. 할 일이 많으니 일 외에 다른 것은 하면 안된다고 느낀다. 그러나 하기 싫은걸 제대로 할리가 없다. 결국 아무것도 안하며