장바구니 담기 close

장바구니에 상품을 담았습니다.

스프링 마이크로서비스 코딩 공작소 개정2판

스프링 마이크로서비스 코딩 공작소 개정2판

  • 존카넬 ,일러리후알리루포산체스
  • |
  • 길벗
  • |
  • 2022-06-30 출간
  • |
  • 524페이지
  • |
  • 183 X 235 X 21 mm
  • |
  • ISBN 9791140700448
판매가

38,000원

즉시할인가

34,200

배송비

무료배송

(제주/도서산간 배송 추가비용:3,000원)

수량
+ -
총주문금액
34,200

※ 스프링제본 상품은 반품/교환/환불이 불가능하므로 신중하게 선택하여 주시기 바랍니다.

출판사서평




이론은 탄탄하게,실습은 실무에 가깝게!

스프링 부트 + 스프링 클라우드로 시작하자
마이크로서비스는 서비스 개발, 그 이상(클라우드, 인프라, 자동화, 테스팅, 회복성, 보안, 인증, 로깅, 모니터링, 배포 등)을 필요로 한다. 클라우드를 사용하면 안정성, 생산성, 확장성, 유지 보수 등 여러 가지 면에서 유용하다. 책에서는 이러한 장점이 있는 스프링 클라우드를 사용해 마이크로서비스의 빌드와 배포를 최소화한다. 스프링 부트와 스프링 클라우드로 마이크로서비스를 시작해 보자.

현실적이고 실용적인 코드로 학습하자
MSA/클라우드 네이티브 환경에서 다양한 프로젝트를 경험한 아키텍트와 개발자로 활동해 온 두 명의 저자가 현업에서 활용 가능한 최신 컨테이너 기반의 마이크로서비스 코드를 수록했다. 스프링 부트와 스프링 클라우드 2 버전에 호환되는 실용적인 예제를 직접 실행하며 마이크로서비스의 개념을 확실히 이해할 수 있다.

핵심 패턴을 익히자
마이크로서비스를 개념적으로 이해하고 작성하는 것은 가능하지만, 대규모 마이크로서비스 애플리케이션을 클라우드에서 배포하고 운영하는 것은 코드를 작성하는 것 이상을 필요로 한다. 책에서는 핵심 마이크로서비스 개발 패턴, 라우팅 패턴, 클라이언트 회복성 패턴, 구축/배치 패턴 등 주요 개념을 스프링 부트와 스프링 클라우드로 구현한다.


목차


1장 스프링, 클라우드와 만나다
1.1 마이크로서비스 아키텍처로 진화
__1.1.1 N-계층 아키텍처
__1.1.2 모놀리스 아키텍처
__1.1.3 마이크로서비스란?
__1.1.4 애플리케이션 구축 방법을 왜 바꾸어야 할까?
1.2 스프링 마이크로서비스
1.3 우리가 구축할 것은 무엇인가?
1.4 이 책의 내용
__1.4.1 이 책에서 배울 내용
__1.4.2 이 책의 연관성
1.5 클라우드 및 마이크로서비스 기반 애플리케이션
__1.5.1 스프링 부트로 마이크로서비스 구축하기
__1.5.2 클라우드 컴퓨팅이란 정확히 무엇인가?
__1.5.3 왜 클라우드와 마이크로서비스인가?
1.6 마이크로서비스는 코드 작성 이상을 의미한다
1.7 핵심 마이크로서비스 개발 패턴
1.8 마이크로서비스 라우팅 패턴
1.9 마이크로서비스 클라이언트 회복성
1.10 마이크로서비스 보안 패턴
1.11 마이크로서비스 로깅과 추적 패턴
1.12 애플리케이션 지표 패턴
1.13 마이크로서비스 빌드/배포 패턴
1.14 요약

2장 스프링 클라우드와 함께 마이크로서비스 세계 탐험
2.1 스프링 클라우드란?
__2.1.1 스프링 클라우드 컨피그
__2.1.2 스프링 클라우드 서비스 디스커버리
__2.1.3 스프링 클라우드 로드 밸런서와 Resilience4j
__2.1.4 스프링 클라우드 API 게이트웨이
__2.1.5 스프링 클라우드 스트림
__2.1.6 스프링 클라우드 슬루스
__2.1.7 스프링 클라우드 시큐리티
2.2 스프링 클라우드 예제 소개
2.3 클라우드 네이티브 마이크로서비스 구축 방법
__2.3.1 코드베이스
__2.3.2 의존성
__2.3.3 구성 정보
__2.3.4 백엔드 서비스
__2.3.5 빌드, 릴리스, 실행
__2.3.6 프로세스
__2.3.7 포트 바인딩
__2.3.8 동시성
__2.3.9 폐기 가능
__2.3.10 개발 및 운영 환경 일치
__2.3.11 로그
__2.3.12 관리 프로세스
2.4 적절한 예제 도입
2.5 스프링 부트와 자바로 마이크로서비스 만들기
__2.5.1 환경 설정
__2.5.2 뼈대 프로젝트 시작하기
__2.5.3 스프링 부트 애플리케이션 부팅하기: 부트스트랩 클래스 작성
2.6 요약

3장 스프링 부트로 마이크로서비스 구축하기
3.1 아키텍트 이야기: 마이크로서비스 아키텍처 설계
__3.1.1 비즈니스 문제 분해
__3.1.2 서비스 세분화 확정
__3.1.3 서비스 인터페이스 설계
3.2 마이크로서비스를 사용하지 말아야 할 때
__3.2.1 분산 시스템 구축의 복잡성
__3.2.2 서버 또는 컨테이너 스프롤
__3.2.3 애플리케이션 타입
__3.2.4 데이터 트랜잭션과 일관성
3.3 개발자 이야기: 스프링 부트와 자바
__3.3.1 마이크로서비스의 출입구 만들기: 스프링 부트 컨트롤러
__3.3.2 라이선싱 서비스에 국제화 추가하기
__3.3.3 관련 링크를 표시하는 스프링 HATEOAS 구현
3.4 데브옵스 이야기: 혹독한 런타임 구축
__3.4.1 서비스 조립: 마이크로서비스의 패키징과 배포
__3.4.2 서비스 부트스트래핑: 마이크로서비스의 구성 관리
__3.4.3 서비스 등록과 디스커버리: 클라이언트가 마이크로서비스와 통신하는 방법
__3.4.4 마이크로서비스의 상태 전달
3.5 모든 관점 통합하기
3.6 요약

4장 도커
4.1 컨테이너 또는 가상 머신?
4.2 도커란?
4.3 Dockerfiles
4.4 도커 컴포즈
4.5 마이크로서비스와 도커 통합하기
__4.5.1 도커 이미지 만들기
__4.5.2 스프링 부트로 도커 이미지 생성하기
__4.5.3 도커 컴포즈로 서비스 실행하기
4.6 요약

5장 스프링 클라우드 컨피그 서버로 구성 관리
5.1 구성(그리고 복잡성) 관리
__5.1.1 구성 관리 아키텍처
__5.1.2 구현 솔루션 선택
5.2 스프링 클라우드 컨피그 서버 구축
__5.2.1 스프링 클라우드 컨피그 부트스트랩 클래스 설정
__5.2.2 스프링 클라우드 컨피그 서버에 파일 시스템 사용
__5.2.3 서비스의 구성 파일 설정
5.3 스프링 클라우드 컨피그와 스프링 부트 클라이언트 통합
__5.3.1 라이선싱 서비스의 스프링 클라우드 컨피그 서비스 의존성 설정
__5.3.2 스프링 클라우드 컨피그 사용을 위한 라이선싱 서비스 구성
__5.3.3 스프링 클라우드 컨피그 서버를 사용하여 데이터 소스 연결
__5.3.4 @ConfigurationProperties를 사용하여 프로퍼티 직접 읽기
__5.3.5 스프링 클라우드 컨피그 서버를 사용하여 프로퍼티 갱신
__5.3.6 깃과 함께 스프링 클라우드 컨피그 서버 사용
__5.3.7 볼트와 스프링 클라우드 컨피그 서비스 통합
__5.3.8 볼트 UI
5.4 중요한 구성 정보 보호
__5.4.1 대칭 암호화 키 설정
__5.4.2 프로퍼티 암호화와 복호화
5.5 마치며
5.6 요약

6장 서비스 디스커버리
6.1 서비스 위치 확인
6.2 클라우드에서 서비스 디스커버리
__6.2.1 서비스 디스커버리 아키텍처
__6.2.2 스프링과 넷플릭스 유레카를 사용한 서비스 디스커버리
6.3 스프링 유레카 서비스 구축
6.4 스프링 유레카에 서비스 등록
__6.4.1 유레카 REST API
__6.4.2 유레카 대시보드
6.5 서비스 디스커버리를 이용한 서비스 검색
__6.5.1 스프링 Discovery Client로 서비스 인스턴스 검색
__6.5.2 로드 밸런서를 지원하는 스프링 REST 템플릿으로 서비스 호출
__6.5.3 넷플릭스 Feign 클라이언트로 서비스 호출
6.6 요약

7장 나쁜 상황에 대비한 스프링 클라우드와 Resilience4j를 사용한 회복성 패턴
7.1 클라이언트 측 회복성이란?
__7.1.1 클라이언트 측 로드 밸런싱
__7.1.2 회로 차단기
__7.1.3 폴백 처리
__7.1.4 벌크헤드
7.2 클라이언트 회복성이 중요한 이유
7.3 Resilience4j 구현
7.4 스프링 클라우드와 Resilience4j를 사용하는 라이선싱 서비스 설정
7.5 회로 차단기 구현
__7.5.1 조직 서비스에 회로 차단기 추가
__7.5.2 회로 차단기 사용자 정의
7.6 폴백 처리
7.7 벌크헤드 패턴 구현
7.8 재시도 패턴 구현
7.9 속도 제한기 패턴 구현
7.10 ThreadLocal과 Resilience4j
7.11 요약

8장 스프링 클라우드 게이트웨이를 이용한 서비스 라우팅
8.1 서비스 게이트웨이란?
8.2 스프링 클라우드 게이트웨이 소개
__8.2.1 스프링 부트 게이트웨이 프로젝트 설정
__8.2.2 유레카와 통신하는 스프링 클라우드 게이트웨이 구성
8.3 스프링 클라우드 게이트웨이에서 라우팅 구성
__8.3.1 서비스 디스커버리를 이용한 자동 경로 매핑
__8.3.2 서비스 디스커버리를 이용한 수동 경로 매핑
__8.3.3 동적으로 라우팅 구성을 재로딩
8.4 스프링 클라우드 게이트웨이의 진정한 능력: Predicate과 Filter Factories
__8.4.1 게이트웨이 Predicate Factories
__8.4.2 게이트웨이 Filter Factories
__8.4.3 사용자 정의 필터
8.5 사전 필터 만들기
8.6 서비스에서 상관관계 ID 사용
__8.6.1 유입되는 HTTP 요청을 가로채는 UserContextFilter
__8.6.2 서비스에 쉽게 액세스할 수 있는 HTTP 헤더를 만드는 UserContext
__8.6.3 상관관계 ID 전파를 위한 사용자 정의 RestTemplate과 UserContextInterceptor
8.7 상관관계 ID를 수신하는 사후 필터 작성
8.8 요약

9장 마이크로서비스 보안
9.1 OAuth2 소개
9.2 키클록 소개
9.3 작게 시작하기: 스프링과 키클록으로 한 개의 엔드포인트 보호
__9.3.1 도커에 키클록 추가하기
__9.3.2 키클록 설정
__9.3.3 클라이언트 애플리케이션 등록
__9.3.4 O-stock 사용자 구성
__9.3.5 O-stock 사용자 인증
9.4 키클록으로 조직 서비스 보호하기
__9.4.1 스프링 시큐리티와 키클록 JARs를 서비스에 추가
__9.4.2 키클록 서버 접속을 위한 서비스 구성
__9.4.3 서비스에 접근할 수 있는 사용자 및 대상 정의
__9.4.4 액세스 토큰 전파
__9.4.5 JWT의 사용자 정의 필드 파싱
9.5 마이크로서비스 보안을 마치며
__9.5.1 모든 서비스 통신에 HTTPS/SSL을 사용하라
__9.5.2 서비스 게이트웨이를 사용하여 마이크로서비스에 접근하라
__9.5.3 공개 API 및 비공개 API 영역을 지정하라
__9.5.4 불필요한 네트워크 포트를 차단해서 마이크로서비스 공격 지점을 제한하라
9.6 요약

10장 스프링 클라우드 스트림을 사용한 이벤트 기반 아키텍처
10.1 메시징과 EDA, 마이크로서비스의 사례
__10.1.1 동기식 요청- 응답 방식으로 상태 변화 전달
__10.1.2 메시징을 사용한 서비스 간 상태 변화 전달
__10.1.3 메시징 아키텍처의 단점
10.2 스프링 클라우드 스트림 소개
10.3 간단한 메시지 생산자와 소비자 작성
__10.3.1 아파치 카프카 및 레디스 도커 구성
__10.3.2 조직 서비스에서 메시지 생산자 작성
__10.3.3 라이선싱 서비스에서 메시지 소비자 작성
__10.3.4 메시지 서비스 동작 보기
10.4 스프링 클라우드 스트림 사용 사례: 분산 캐싱
__10.4.1 캐시 검색을 위한 레디스
__10.4.2 사용자 정의 채널 설정
10.5 요약

11장 스프링 클라우드 슬루스와 집킨을 이용한 분산 추적
11.1 스프링 클라우드 슬루스와 상관관계 ID
__11.1.1 라이선싱 및 조직 서비스에 스프링 클라우드 슬루스 추가
__11.1.2 스프링 클라우드 슬루스의 추적 분석
11.2 로그 수집과 스프링 클라우드 슬루스
__11.2.1 동작하는 스프링 클라우드 슬루스/ELK 스택 구현
__11.2.2 서비스에서 로그백 구성
__11.2.3 도커에서 ELK 스택 애플리케이션 정의 및 실행
__11.2.4 키바나 구성
__11.2.5 키바나에서 스프링 클라우드 슬루스의 추적 ID 검색
11.3 집킨을 사용한 분산 추적
__11.3.1 스프링 클라우드 슬루스와 집킨 의존성 설정
__11.3.2 집킨 연결을 위한 서비스 구성 설정
__11.3.3 집킨 서버 구성
__11.3.4 추적 레벨 설정
__11.3.5 집킨으로 트랜잭션 추적
__11.3.6 더 복잡한 트랜잭션의 시각화
__11.3.7 메시징 추적 수집
__11.3.8 사용자 정의 스팬
11.4 요약

12장 마이크로서비스 배포
12.1 빌드/배포 파이프라인 아키텍처
12.2 클라우드에 O-stock 핵심 인프라스트럭처 설정
__12.2.1 아마존 RDS를 사용한 PostgreSQL 데이터베이스 생성
__12.2.2 아마존에 레디스 클러스터 구축
12.3 인프라스트럭처를 넘어: O-stock과 ELK 배포
__12.3.1 ELK EC2 생성
__12.3.2 EC2 인스턴스에 ELK 스택 배포
__12.3.3 EKS 클러스터 생성
12.4 빌드/배포 파이프라인 인 액션
12.5 빌드/배포 파이프라인 생성
__12.5.1 깃허브 설정
__12.5.2 젠킨스에서 서비스 빌드 활성화
__12.5.3 파이프라인 스크립트 이해 및 작성
__12.5.4 쿠버네티스 파이프라인 스크립트 작성
12.6 빌드/배포 파이프라인 고찰
12.7 요약

부록 A 마이크로서비스 아키텍처 모범 사례
A.1 리처드슨 성숙도 모델
A.2 스프링 HATEOAS
A.3 구성 외부화
A.4 지속적 통합(CI)과 지속적 전달(CD)
A.5 모니터링
A.6 로깅
A.7 API 게이트웨이

부록 B OAuth2 그랜트 타입
B.1 패스워드 그랜트 타입
B.2 클라이언트 자격 증명 그랜트 타입
B.3 인가 코드 그랜트 타입
B.4 암시적 그랜트 타입
B.5 토큰 리프레시 방법

부록 C 서비스 모니터링
C.1 스프링 부트 액추에이터로 모니터링
__C.1.1 스프링 부트 액추에이터 추가
__C.1.2 액추에이터 엔드포인트 활성화
C.2 마이크로미터와 프로메테우스 설정
__C.2.1 마이크로미터와 프로메테우스의 이해
__C.2.2 마이크로미터와 프로메테우스 구현
C.3 그라파나 구성
C.4 요약

교환 및 환불안내

도서교환 및 환불
  • ㆍ배송기간은 평일 기준 1~3일 정도 소요됩니다.(스프링 분철은 1일 정도 시간이 더 소요됩니다.)
  • ㆍ상품불량 및 오배송등의 이유로 반품하실 경우, 반품배송비는 무료입니다.
  • ㆍ고객님의 변심에 의한 반품,환불,교환시 택배비는 본인 부담입니다.
  • ㆍ상담원과의 상담없이 교환 및 반품으로 반송된 물품은 책임지지 않습니다.
  • ㆍ이미 발송된 상품의 취소 및 반품, 교환요청시 배송비가 발생할 수 있습니다.
  • ㆍ반품신청시 반송된 상품의 수령후 환불처리됩니다.(카드사 사정에 따라 카드취소는 시일이 3~5일이 소요될 수 있습니다.)
  • ㆍ주문하신 상품의 반품,교환은 상품수령일로 부터 7일이내에 신청하실 수 있습니다.
  • ㆍ상품이 훼손된 경우 반품 및 교환,환불이 불가능합니다.
  • ㆍ반품/교환시 고객님 귀책사유로 인해 수거가 지연될 경우에는 반품이 제한될 수 있습니다.
  • ㆍ스프링제본 상품은 교환 및 환불이 불가능 합니다.
  • ㆍ군부대(사서함) 및 해외배송은 불가능합니다.
  • ㆍ오후 3시 이후 상담원과 통화되지 않은 취소건에 대해서는 고객 반품비용이 발생할 수 있습니다.
반품안내
  • 마이페이지 > 나의상담 > 1 : 1 문의하기 게시판 또는 고객센터 : 070-4821-5101
교환/반품주소
  • 부산광역시 부산진구 중앙대로 856 303호 / (주)스터디채널 / 전화 : 070-4821-5101
  • 택배안내 : CJ대한통운(1588-1255)
  • 고객님 변심으로 인한 교환 또는 반품시 왕복 배송비 5,000원을 부담하셔야 하며, 제품 불량 또는 오 배송시에는 전액을 당사에서부담 합니다.