이미지 검색을 사용해 보세요
검색창 이전화면 이전화면
최근 검색어
인기 검색어

소득공제 PDF
eBook 자바 잘 읽는 법
자바 코드를 이해하고, 디버깅하고, 최적화하는 요령 스마트한 PDF 필기 기능을 사용해 보세요!
가격
19,600
19,600
YES포인트?
980원 (5%)
5만원 이상 구매 시 2천원 추가 적립
결제혜택
카드/간편결제 혜택을 확인하세요
PDF 안내

이 상품은 구매 후 지원 기기에서 예스24 eBook앱 설치 후 바로 이용 가능한 상품입니다.

예스24만의 독보적인 PDF 필기 기능을 경험해 보세요!

카드뉴스로 보는 책

카드뉴스0
카드뉴스1
카드뉴스2
카드뉴스3
카드뉴스4
카드뉴스5
카드뉴스6
카드뉴스7

상세 이미지

소개

목차

옮긴이 머리말 x
베타리더 후기 xi
시작하며 xiv
감사의 글 xvi
이 책에 대하여 xviii
표지에 대하여 xxi

PART I 트러블슈팅 기본 테크닉

CHAPTER 1 앱에서 모호한 부분 밝히기 3
1.1 앱을 더 쉽게 이해하는 방법 4
1.2 일반적인 코드 조사 시나리오 8
__1.2.1 예상과 다른 아웃풋의 원인을 밝힌다 9
__1.2.2 특정 기술을 습득한다 14
__1.2.3 속도 저하 이유를 알아낸다 15
__1.2.4 앱 크래시가 발생하는 이유를 이해한다 16
1.3 이 책에서 배울 내용 19
요약 20

CHAPTER 2 디버깅 기법으로 앱 로직 이해하기 21
2.1 코드 분석만으로는 불충분한 경우 23
2.2 디버거를 이용한 코드 조사 26
__2.2.1 실행 스택 트레이스란 무엇이고 어떻게 사용해야 할까? 31
__2.2.2 디버거로 코드 탐색하기 36
2.3 디버거로도 충분하지 않다면 43
요약 45

CHAPTER 3 고급 디버깅 기법으로 문제의 근본 원인 찾기 47
3.1 조건부 브레이크포인트로 조사 시간 최소화 48
3.2 실행을 중단시키지 않고도 브레이크포인트를 사용하는 방법 52
3.3 조사 시나리오를 동적으로 변경하기 55
3.4 조사 케이스를 되감기 58
요약 64

CHAPTER 4 원격 앱 디버깅 65
4.1 원격 디버깅이란? 66
4.2 원격 환경에서 조사하기 69
__4.2.1 시나리오 70
__4.2.2 원격 환경의 문제 조사하기 71
요약 81

CHAPTER 5 로그를 활용하여 앱 동작 감시하기 83
5.1 로그를 이용하여 조사하기 87
__5.1.1 로그에 기록된 예외 식별 88
__5.1.2 예외 스택 트레이스로 어디서 메서드를 호출했는지 식별 89
__5.1.3 멀티스레드 아키텍처에서 커맨드의 실행 시간 측정 91
__5.1.4 멀티스레드 아키텍처에서 커맨드 실행 문제 조사 92
5.2 로깅을 구현하는 방법 94
__5.2.1 로그 메시지 저장 94
__5.2.2 로깅 레벨을 정의하고 로깅 프레임워크를 사용하는 방법 95
__5.2.3 로깅 때문에 발생하는 문제와 예방 조치 102
5.3 로그와 원격 디버깅 107
요약 108

PART II 트러블슈팅 고급 테크닉

CHAPTER 6 프로파일링 기법으로 리소스 사용 문제 파악하기 111
6.1 프로파일러는 어떤 경우에 유용할까? 112
__6.1.1 비정상적인 리소스 사용량 식별 112
__6.1.2 실행되는 코드 찾기 113
__6.1.3 앱 실행 속도가 느려지는 원인을 파악 114
6.2 프로파일러 사용 방법 114
__6.2.1 VisualVM 설치 및 구성 115
__6.2.2 CPU와 메모리 사용량 관찰 117
__6.2.3 메모리 누수 현상 식별 127
요약 132

CHAPTER 7 프로파일링 기법으로 숨겨진 이슈 찾기 133
7.1 샘플링으로 실행되는 코드 관찰 134
7.2 프로파일링으로 메서드의 실행 횟수 파악 142
7.3 프로파일러로 앱이 실제로 실행하는 SQL 쿼리 파악 144
__7.3.1 프로파일러로 프레임워크에서 생성되지 않은 SQL 쿼리 식별 144
__7.3.2 프로파일러로 프레임워크에서 생성된 SQL 쿼리 식별 150
__7.3.3 프로파일러로 프로그램에서 생성된 SQL 쿼리 식별 153
요약 157

CHAPTER 8 프로파일링한 데이터에 고급 시각화 도구 적용하기 159
8.1 JDBC 접속 문제 감지 160
8.2 호출 그래프를 보고 앱의 코드 설계 파악 173
8.3 플레임 그래프를 그려 성능 문제 밝히기 175
8.4 NoSQL DB에서의 쿼리 분석 179
요약 180

CHAPTER 9 멀티스레드 아키텍처의 락 문제 조사하기 183
9.1 스레드 락 모니터링 184
9.2 스레드 락 분석 189
9.3 대기 중인 스레드 분석 198
요약 205

CHAPTER 10 스레드 덤프로 데드락 문제 조사하기 207
10.1 스레드 덤프 수집하기 208
__10.1.1 프로파일러로 스레드 덤프 수집 210
__10.1.2 커맨드 라인에서 스레드 덤프 수집 212
10.2 스레드 덤프를 읽는 방법 215
__10.2.1 일반 텍스트 스레드 덤프 216
__10.2.2 도구를 활용하여 스레드 덤프 읽기 222
요약 225

CHAPTER 11 앱 실행 중 메모리 관련 이슈 찾기 227
11.1 샘플링과 프로파일링으로 메모리 이슈 진단 228
11.2 힙 덤프를 수집하여 메모리 누수가 발생하는 곳 찾기 235
__11.2.1 힙 덤프 수집 236
__11.2.2 힙 덤프 읽는 방법 240
__11.2.3 OQL 콘솔에서 힙 덤프 쿼리 245
요약 251

PART III 대규모 시스템의 트러블슈팅

CHAPTER 12 대규모 시스템에 배포된 앱의 동작 조사하기 255
12.1 서비스 간 통신 문제 조사 256
__12.1.1 HTTP 서버 프로브로 HTTP 요청 관찰 257
__12.1.2 HTTP 클라이언트 프로브로 앱이 보낸 HTTP 요청 관찰 259
__12.1.3 소켓의 로 레벨 이벤트 조사 261
12.2 통합 로그 모니터링의 중요성 263
12.3 배포 도구를 조사에 활용하는 법 270
__12.3.1 결함 주입으로 재현하기 곤란한 문제를 비슷하게 모방 272
__12.3.2 미러링 기법을 테스트 및 에러 감지에 활용 273
요약 274

APPENDIX A 이 책에서 사용한 도구 275

APPENDIX B 프로젝트 열기 277

APPENDIX C 기타 참고 도서 279

APPENDIX D 자바 스레드 이해 281

D.1 스레드란 무엇인가? 282
D.2 스레드의 수명 주기 284
D.3 스레드 동기화 286
__D.3.1 동기화 블록 286
__D.3.2 wait(), notify(), notifyAll() 사용 289
__D.3.3 스레드 조인 290
__D.3.4 정해진 시간 동안 스레드 차단 291
__D.3.5 스레드와 블로킹 객체 동기화하기 292
D.4 멀티스레드 아키텍처의 일반적인 문제 293
__D.4.1 경쟁 상태 293
__D.4.2 데드락 294
__D.4.3 리브락 295
__D.4.4 기아 296
D.5 추가 자료 297

APPENDIX E 자바 메모리 관리 체계 299
E.1 JVM이 앱의 메모리를 구성하는 방법 300
E.2 스레드가 로컬 데이터를 저장하는 데 사용하는 스택 302
E.3 앱이 객체 인스턴스를 저장하는 데 사용하는 힙 308
E.4 데이터 유형을 저장하기 위한 메타스페이스 메모리 위치 311

찾아보기 313

저자 소개2

로렌티우 스필카

관심작가 알림신청
 

Laurentiu Spilca

엔다바(Endava)에서 전문 개발 리드이자 트레이너로 일하며 유럽, 미국, 아시아의 고객을 대상으로 하는 금융 시장 프로젝트의 개발을 이끌고 있다. 10년 이상의 경력이 있는 그는 고품질의 소프트웨어를 제공하는 것뿐만 아니라 지식을 공유하고 다른 이들의 역량 향상을 돕는 것이 중요하다고 믿는다. 이러한 신념은 그가 자바 기술 관련 코스를 설계하고 가르치며, 발표와 워크숍을 진행하도록 이끌었다.

로렌티우 스필카의 다른 상품

20년 가까이 국내외 엔터프라이즈 현장에서 자바 전문 풀스택 개발자, 소프트웨어/애플리케이션 아키텍트로 프로젝트를 수행했다. 어느덧 50대를 바라보는 중년 아재가 됐지만 아직도 궁금한 기술이 많은 엔지니어이고, 20여 권의 IT 전문서를 번역하며 동료, 후배 개발자들과 지식과 경험을 나누는 일에도 힘쓰고 있다. 이벤트 기반의 마이크로서비스 아키텍처 설계에 많은 관심을 갖게 되었으며, 카프카 기술에도 관심이 많아 콘플루언트 인증 아파치 카프카 개발자/관리자(CCDAK, CCAAK) 자격을 취득했다. 십수 년간 다양한 엔터프라이즈 프로젝트 현장을 누벼왔고 이제는 어느덧 중년 아재가
20년 가까이 국내외 엔터프라이즈 현장에서 자바 전문 풀스택 개발자, 소프트웨어/애플리케이션 아키텍트로 프로젝트를 수행했다. 어느덧 50대를 바라보는 중년 아재가 됐지만 아직도 궁금한 기술이 많은 엔지니어이고, 20여 권의 IT 전문서를 번역하며 동료, 후배 개발자들과 지식과 경험을 나누는 일에도 힘쓰고 있다. 이벤트 기반의 마이크로서비스 아키텍처 설계에 많은 관심을 갖게 되었으며, 카프카 기술에도 관심이 많아 콘플루언트 인증 아파치 카프카 개발자/관리자(CCDAK, CCAAK) 자격을 취득했다. 십수 년간 다양한 엔터프라이즈 프로젝트 현장을 누벼왔고 이제는 어느덧 중년 아재가 되었지만, 아직도 코드와 씨름하며 열정적인 기술자로서 활동 중인 두 딸의 아빠다. 소질과 실력은 없지만 시간이 나면 클래식 피아노곡을 즐겨 연주한다.

이일웅 의 다른 상품

품목정보

발행일
2024년 06월 14일
이용안내
  •  배송 없이 구매 후 바로 읽기
  •  이용기간 제한없음
  •   TTS 가능 ?
  •  저작권 보호를 위해 인쇄 기능 제공 안함
지원기기
크레마, PC(윈도우 - 4K 모니터 미지원), 아이폰, 아이패드, 안드로이드폰, 안드로이드패드, 전자책단말기(저사양 기기 사용 불가), PC(Mac)
파일/용량
PDF(DRM) | 17.64MB ?
글자 수/ 페이지 수
약 342쪽 ?
ISBN13
9791193926376

출판사 리뷰

코드 독해력을 높여 JVM 코드를 이해하고 디버깅하고 최적화하는 요령

커리어가 쌓일수록 코드를 작성하는 시간보다 코드를 읽는 시간이 훨씬 더 길어진다. 그 긴 시간을 효율적으로 쓰기 위한 코드 조사 기법을 다루는 게 바로 이 책이다. 디버깅이나 로깅의 기초부터 고급 프로파일링 기법과 JVM 애플리케이션의 작동 원리까지, 개발자 친화적인 시나리오 중심으로 트러블슈팅을 설명한다는 점이 큰 장점이다.

1부는 코드베이스를 파악하기 위한 조사 기법의 기초를 다룬다. 2~4장에서는 디버깅을 중심으로 간단히 브레이크포인트를 찍는 것부터 원격 디버깅까지 설명하고, 5장은 로그를 이용해 코드 구현과 관련된 필수 세부 정보를 조사하는 방법을 살펴본다.

2부는 프레임워크가 큰 비중을 차지하는 오늘날 개발에서 프로파일링이 얼마나 유용할 수 있는지 잘 보여준다. , VisualVM과 JProfiler 같은 프로파일러 도구를 이용한 6장에서는 CPU와 메모리 사용량을 분석하는 방법을 다루고, 7장에서는 레이턴시 문제를 조사하는 방법을 다룬다. 8, 9장에서는 멀티스레드 아키텍처를 자세히 파헤치고, 10장에서는 스레드 덤프를, 11장에서는 힙 덤프를 생성하여 메모리 문제를 진단하는 방법을 살펴본다.

3부 12장은 단일 앱이 아닌 여러 앱으로 이루어진 대규모 엔터프라이즈 시스템에서 문제를 조사하는 방법을 설명한다. 각 앱이 서로 ‘소통’하는 방식, 앱이 배포된 환경이 미치는 영향, 구현 시 고려 사항 등을 살펴본다. 끝으로 부록에서는 자바 개발자들에게 실질적인 도움이 되는 자바 스레드와 메모리 관리 체계를 정말로 자세히 설명한다.

JVM 애플리케이션이 실제로 어떻게 작동하는지 이해하면 문제의 근본 원인을 찾을 수 있다. 디버깅과 로깅을 올바르게 익힐 수 있는 것은 물론, 마이크로서비스 아키텍처에서 문제를 찾기 위한 고급 기법까지 포괄적으로 다루는, 흔치 않은 책이다.

주요 내용
ㆍ처음 본 코드가 어떤 기능을 하는지 파악하기
ㆍ코드 로직 문제 노출하기
ㆍ힙 덤프를 평가하여 메모리 누수 찾기
ㆍCPU 사용량을 모니터링하여 실행 최적화하기
ㆍ스레드 덤프를 사용하여 교착 상태 찾고 해결하기
ㆍ서비스 지향/마이크로서비스 시스템 이해하기
ㆍ로깅을 제대로 사용하여 자바 앱 실행을 깊이 이해하기
ㆍ자바 디버거를 효율적으로 사용하기

리뷰/한줄평16

리뷰

9.8 리뷰 총점

한줄평

10.0 한줄평 총점

클린봇이 부적절한 글을 감지 중입니다.

설정