스프링 마이크로서비스 코딩 공작소 개정 2판
이론은 탄탄하게, 실습은 실무에 가깝게!
스프링 부트와 스프링 클라우드를 이용한 모범 사례를 직접 실행하며
마이크로서비스의 개념을 확실하게 익히자!
마이크로서비스는 서비스 개발, 그 이상(클라우드, 인프라, 자동화, 테스팅, 회복성, 보안, 인증, 로깅, 모니터링, 배포 등)을 필요로 한다. 클라우드를 사용하면 안정성, 생산성, 확장성, 유지 보수 등 여러 가지 면에서 유용하다. 책에서는 이러한 장점이 있는 스프링 클라우드를 사용해 마이크로서비스의 빌드와 배포를 최소화하도록 했다. 스프링 부트와 스프링 클라우드, 도커, 하시코프 볼트, 아파치 카프카, 키클록, 오픈 집킨, ELK 스택, 그라파나, 프로메테우스, AWS EKS, 깃허브/젠킨스를 사용해 쿠버네티스 기반의 마이크로서비스를 구축해보면서 개념과 실무를 동시에 배울 수 있다. 또한, 핵심 마이크로서비스 개발 패턴, 라우팅 패턴, 클라이언트 회복성 패턴, 구축/배치 패턴 등 주요 패턴도 함께 살펴본다. 이 책을 통해 어떻게 서비스를 만들고 개선해 나갈 수 있는지에 대한 다양한 고민들에 대한 해법을 찾을 수 있을 것이다.
«스프링 마이크로서비스 코딩 공작소 개정 2판»은 3~6장을 공개합니다.
목차
- 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.2 키클록 서버 접속을 위한 서비스 구성
- 9.4.3 서비스에 접근할 수 있는 사용자 및 대상 정의
- 9.4.4 액세스 토큰 전파
- 9.4.5 JWT의 사용자 정의 필드 파싱
- 9.4.1 스프링 시큐리티와 키클록 JARs를 서비스에 추가
- 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 요약