본문 바로가기

추천 검색어

실시간 인기 검색어

스프링으로 하는 마이크로서비스 구축 2/e

스프링 부트와 스프링 클라우드, 이스티오를 이용한 확장 가능한 마이크로서비스 구축
소프트웨어 아키텍처
매그너스 라슨 저자(글) · 박규태 번역
에이콘출판 · 2024년 06월 27일
가장 최근에 출시된 개정판입니다. 구판보기
0.0
10점 중 0점
(0개의 리뷰)
평가된 감성태그가
없습니다
  • 스프링으로 하는 마이크로서비스 구축 2/e 대표 이미지
    스프링으로 하는 마이크로서비스 구축 2/e 대표 이미지
  • A4
    사이즈 비교
    210x297
    스프링으로 하는 마이크로서비스 구축 2/e 사이즈 비교 187x235
    단위 : mm
01 / 02
무료배송 소득공제
10% 40,500 45,000
적립/혜택
2,250P

기본적립

5% 적립 2,250P

추가적립

  • 5만원 이상 구매 시 추가 2,000P
  • 3만원 이상 구매 시, 등급별 2~4% 추가 최대 2,250P
  • 리뷰 작성 시, e교환권 추가 최대 300원
배송안내
무료배송
배송비 안내
국내도서/외국도서
도서 포함 15,000원 이상 구매 시 무료배송
도서+사은품 또는 도서+사은품+교보Only(교보굿즈)

15,000원 미만 시 2,500원 배송비 부과

교보Only(교보배송)
각각 구매하거나 함께 20,000원 이상 구매 시 무료배송

20,000원 미만 시 2,500원 배송비 부과

해외주문 서양도서/해외주문 일본도서(교보배송)
각각 구매하거나 함께 15,000원 이상 구매 시 무료배송

15,000원 미만 시 2,500원 배송비 부과

업체배송 상품(전집, GIFT, 음반/DVD 등)
해당 상품 상세페이지 "배송비" 참고 (업체 별/판매자 별 무료배송 기준 다름)
바로드림 오늘배송
업체에서 별도 배송하여 1Box당 배송비 2,500원 부과

1Box 기준 : 도서 10권

그 외 무료배송 기준
바로드림, eBook 상품을 주문한 경우, 플래티넘/골드/실버회원 무료배송쿠폰 이용하여 주문한 경우, 무료배송 등록 상품을 주문한 경우
당일배송 오늘(2/26,수) 도착
기본배송지 기준
배송일자 기준 안내
로그인 : 회원정보에 등록된 기본배송지
로그아웃 : '서울시 종로구 종로1' 주소 기준
로그인정확한 배송 안내를 받아보세요!

이달의 꽃과 함께 책을 받아보세요!

1권 구매 시 결제 단계에서 적용 가능합니다.

알림 신청하시면 원하시는 정보를
받아 보실 수 있습니다.

키워드 Pick

키워드 Pick 안내

관심 키워드를 주제로 다른 연관 도서를 다양하게 찾아 볼 수 있는 서비스로, 클릭 시 관심 키워드를 주제로 한 다양한 책으로 이동할 수 있습니다.
키워드는 최근 많이 찾는 순으로 정렬됩니다.

기존 일체형 애플리케이션을 마이크로서비스로 나누고 온프레미스나 클라우드로 배포하려는 자바, 스프링 개발자와 아키텍트를 위한 책이다.
스프링 부트, 스프링 클라우드와 도커, 쿠버네티스, 이스티오, EFK 스택, 프로메테우스, 그라파나 등의 오픈소스 도구를 조합해 마이크로서비스를 구축하는 방법을 설명한다. 오픈소스 도구와 스프링 기반 자바 코드를 실습 위주로 설명하며, 최소한의 시간 투자만으로도 다양하고 넓은 범위의 지식을 학습할 수 있게끔 효율적으로 구성돼 있다.
개정판은 스프링 부트와 다양한 오픈소스 도구의 최신 버전을 사용해 보다 쉽고 빠르게 학습할 수 있도록 내용을 업데이트했으며, 스프링 기반 마이크로서비스를 네이티브 컴파일하는 방법, 윈도우 WSL 2 환경 설정 방법, 헬름 3 사용 방법 등의 내용을 추가했다.

북 트레일러

  • 출판사의 사정에 따라 서비스가 변경 또는 중지될 수 있습니다.
  • Window7의 경우 사운드 연결이 없을 시, 동영상 재생에 오류가 발생할 수 있습니다. 이어폰, 스피커 등이 연결되어 있는지 확인 하시고 재생하시기 바랍니다.

이 책의 총서 (9)

작가정보

저자(글) 매그너스 라슨

Magnus Larsson
35년 이상 IT 산업에 종사했으며 볼보(Volvo), 에릭슨(Ericsson), 아스트라제네카(AstraZeneca) 등 스웨덴 대기업의 컨설턴트로 일하고 있다. 예전에 겪었던 분산 시스템과 관련된 어려운 문제를 스프링 클라우드, 쿠버네티스, 이스티오 등의 오픈소스 도구를 이용해 해결하고 있다. 지난 몇 년 동안 고객이 이런 도구를 사용하도록 도왔고 해당 주제에 대해 여러 번 발표했으며 블로그 게시물도 작성했다.

번역 박규태

엔터프라이즈 자바 환경에서 오랫동안 일했다. CMS, 웹 오피스, 쿠버네티스 기반 GPU 플랫폼을 개발했으며, 지금은 OpenTelemetry 기반 모니터링 솔루션을 개발하고 있다.

작가의 말

스프링 부트와 스프링 클라우드를 사용해 상용 마이크로서비스를 구축하는 방법을 설명하는 책이다. 내가 처음 마이크로서비스 학습을 시작한 8년 전에 바로 이런 책을 찾아 헤맸다.
나는 공조 마이크로서비스 환경을 개발, 테스트, 배포, 관리할 때 사용하는 오픈소스 소프트웨어를 학습하고 익숙해진 후에 이 책을 썼다.
주로 스프링 부트, 스프링 클라우드, 도커, 쿠버네티스, 이스티오, EFK 스택(Elasticsearch, Fluentd, Kibana stack), 프로메테우스(Prometheus), 그라파나(Grafana)에 대해 다룬다. 이런 오픈소스 도구는 개별적으로는 훌륭하게 작동하지만, 여러 도구를 어떤 방식으로 조합하는 게 좋을지 알아내기 어렵다. 어떤 영역에서는 상호 보완적이지만 다른 영역에서는 겹쳐서 특정 상황에 맞는 명확한 조합이 있는 것이 아니기 때문이다.
이런 오픈소스 도구를 함께 사용하는 방법을 실습을 바탕으로 단계별로 설명한다. 내가 마이크로서비스 학습을 시작한 8년 전에 이런 책을 찾긴 했지만 오픈소스 도구는 업데이트된 버전을 사용한다.

목차

  • 1부. 스프링 부트를 사용한 마이크로서비스 개발

    1장. 마이크로서비스 소개
    __기술 요구 사항
    __내 마이크로서비스 경험
    ____독립 소프트웨어 컴포넌트의 장점
    ____독립 소프트웨어 컴포넌트의 문제
    ____마이크로서비스 입문
    ____샘플 마이크로서비스 환경
    __마이크로서비스 정의
    __마이크로서비스의 문제
    __마이크로서비스 디자인 패턴
    ____서비스 검색
    ____에지 서버
    ____리액티브 마이크로서비스
    ____구성 중앙화
    ____로그 분석 중앙화
    ____분산 추적
    ____서킷 브레이커
    ____제어 루프
    ____모니터링 및 경고 중앙화
    __필수 소프트웨어
    __다른 주요 고려 사항
    __요약


    2장. 스프링 부트 소개
    __기술 요구 사항
    __스프링 부트
    ____설정보다 관례와 팻 JAR 파일
    ____스프링 부트 애플리케이션 설정에 대한 코드 예제
    __스프링 웹플럭스
    ____REST 서비스 설정에 대한 코드 예제
    __springdoc-openapi
    __스프링 데이터
    ____엔티티
    ____리포지터리
    __스프링 클라우드 스트림
    ____메시지 송수신에 대한 코드 예제
    __도커
    __요약
    __질문


    3장. 공조 마이크로서비스 집합 생성
    __기술 요구 사항
    __마이크로서비스 환경 소개
    ____마이크로서비스가 처리하는 정보
    ____임시로 검색 서비스 대체
    __골격 마이크로서비스 생성
    ____스프링 이니셜라이저로 골격 코드 생성
    ____그래들에 멀티 프로젝트 빌드 설정
    __RESTful API 추가
    ____api 프로젝트와 util 프로젝트 추가
    ____API 구현
    __복합 마이크로서비스 추가
    ____API 클래스
    ____속성
    ____통합 컴포넌트
    ____복합 API 구현
    __예외 처리 추가
    ____전역 REST 컨트롤러 예외 핸들러
    ____API 구현의 예외 처리
    ____API 클라이언트의 예외 처리
    __API 수동 테스트
    __자동화된 마이크로서비스 테스트
    __반자동화된 마이크로서비스 환경 테스트
    ____테스트 스크립트 실행
    __요약
    __질문


    4장. 도커를 사용한 마이크로서비스 배포
    __기술 요구 사항
    __도커 소개
    ____첫 도커 커맨드 실행
    __도커에서 자바를 실행할 때의 문제
    ____사용 가능한 CPU 제한
    ____사용 가능한 메모리 제한
    __도커로 단일 마이크로서비스 실행
    ____소스 코드 변경
    ____도커 이미지 빌드
    ____서비스 시작
    ____컨테이너를 분리 모드로 실행
    __도커 컴포즈를 사용한 마이크로서비스 환경 관리
    ____소스 코드 변경
    ____마이크로서비스 환경 시작
    __공조 마이크로서비스의 테스트 자동화
    ____테스트 실행 문제 해결
    __요약
    __질문


    5장. OpenAPI를 사용한 API 문서화
    __기술 요구 사항
    __springdoc-openapi 소개
    __소스 코드 변경
    ____그래들 빌드 파일에 의존성 추가
    ____ProductCompositeServiceApplication에 구성과 API 정보 추가
    ____ProductCompositeService 인터페이스에 API 정보 추가
    __마이크로서비스 환경 구축 및 시작
    __OpenAPI 문서 사용법
    __요약
    __질문


    6장. 영속성 추가
    __기술 요구 사항
    __목표
    __핵심 마이크로서비스에 영속성 계층 추가
    ____의존성 추가
    ____엔티티 클래스를 사용해 데이터 저장
    ____스프링 데이터 리포지터리 정의
    __영속성에 중점을 둔 자동 테스트 작성
    ____Testcontainers 사용법
    ____영속성 테스트 작성
    __서비스 계층에서 영속성 계층 사용
    ____데이터베이스 연결 URL 기록
    ____새 API 추가
    ____서비스 계층에서 영속성 계층 호출
    ____자바 빈 매퍼 선언
    ____서비스 테스트 업데이트
    __복합 서비스 API 확장
    ____복합 서비스 API에 새 오퍼레이션 추가
    ____통합 계층에 메서드 추가
    ____새 복합 API 오퍼레이션 구현
    ____복합 서비스 테스트 업데이트
    __도커 컴포즈 환경에 데이터베이스 추가
    ____도커 컴포즈 구성
    ____데이터베이스 연결 구성
    ____MongoDB 및 MySQL CLI 도구
    __새 API 및 영속성 계층의 수동 테스트
    __마이크로서비스 환경의 자동 테스트 업데이트
    __요약
    __질문


    7장. 리액티브 마이크로서비스 개발
    __기술 요구 사항
    __논블로킹 동기 API와 이벤트 기반 비동기 서비스의 선택 기준
    __논블로킹 동기 REST API 개발
    ____프로젝트 리액터 소개
    ____스프링 데이터 MongoDB를 사용한 논블로킹 영속성
    ____핵심 서비스의 논블로킹 REST API
    ____복합 서비스의 논블로킹 REST API
    __이벤트 기반 비동기 서비스 개발
    ____메시징 관련 문제 처리
    ____토픽 및 이벤트 정의
    ____그래들 빌드 파일 변경
    ____핵심 서비스에서 이벤트 소비
    ____복합 서비스에서 이벤트 게시
    __리액티브 마이크로서비스 환경의 수동 테스트
    ____이벤트 저장
    ____상태 점검 API 추가
    ____파티션 없이 RabbitMQ 사용
    ____파티션을 추가해 RabbitMQ 사용
    ____토픽당 2개의 파티션으로 카프카 사용
    __리액티브 마이크로서비스 환경의 자동 테스트
    __요약
    __질문


    2부. 스프링 클라우드를 활용한 마이크로서비스 관리

    8장. 스프링 클라우드 소개
    __기술 요구 사항
    __스프링 클라우드의 진화
    __넷플릭스 유레카를 검색 서비스로 사용
    __스프링 클라우드 게이트웨이를 에지 서버로 사용
    __구성 중앙화를 위해 스프링 클라우드 컨피그 사용
    __복원력 향상을 위해 Resilience4j 사용
    ____Resilience4j를 사용한 서킷 브레이커 샘플
    __스프링 클라우드 슬루스와 집킨을 사용한 분산 추적
    __요약
    __질문


    9장. 넷플릭스 유레카를 사용한 서비스 검색
    __기술 요구 사항
    __서비스 검색 소개
    ____DNS 기반 서비스 검색의 문제
    ____서비스 검색의 문제
    ____넷플릭스 유레카를 이용한 서비스 검색
    __넷플릭스 유레카 서버 설정
    __넷플릭스 유레카 서버에 마이크로서비스 연결
    __개발용 구성 설정
    ____유레카 구성 매개 변수
    ____유레카 서버 구성
    ____유레카 서버에 연결할 클라이언트 구성
    __검색 서비스 사용
    ____확장
    ____축소
    ____유레카 서버의 장애 상황 테스트
    __유레카 서버 다시 시작
    __요약
    __질문


    10장. 스프링 클라우드 게이트웨이를 에지 서버로 사용
    __기술 요구 사항
    __시스템 환경에 에지 서버 추가
    __스프링 클라우드 게이트웨이 설정
    ____복합 상태 점검 추가
    ____스프링 클라우드 게이트웨이 구성
    __에지 서버 테스트
    ____도커 엔진 외부로 공개되는 항목 확인
    ____라우팅 규칙 테스트
    __요약
    __질문


    11장. API 접근 보안
    __기술 요구 사항
    __OAuth 2.0 및 OpenID Connect 소개
    ____OAuth 2.0 소개
    ____OpenID Connect 소개
    __시스템 환경 보안
    __HTTPS를 사용한 외부 통신 보호
    ____런타임에 자체 서명 인증서 교체
    __검색 서비스 접근 보안
    ____유레카 서버 변경
    ____유레카 클라이언트 변경
    __로컬 권한 부여 서버 추가
    __OAuth 2.0과 OpenID Connect를 사용한 API 보안
    ____에지 서버와 product-composite 서비스 변경
    ____product-composite 서비스 변경
    ____테스트 스크립트 변경
    __로컬 권한 부여 서버를 사용한 테스트
    ____자동 테스트 빌드 및 실행
    ____검색 서버 보안 테스트
    ____접근 토큰 획득
    ____접근 토큰을 사용해 보안 API 호출
    ____스웨거 UI에서 OAuth 2.0 테스트
    __외부 OpenID Connect 공급자를 사용한 테스트
    ____Auth0 사용자 계정의 설정 및 구성
    ____Auth0를 OpenID 공급자로 사용하기 위해 필요한 변경 사항 적용
    ____Auth0를 OpenID Connect 공급자로 사용해 테스트 스크립트 실행
    ____클라이언트 자격 증명 승인 흐름을 사용해 접근 토큰 획득
    ____권한 코드 승인 흐름을 사용해 접근 토큰 획득
    ____Auth0 접근 토큰을 사용해 보안 API 호출
    ____사용자에 대한 추가 정보 획득
    __요약
    __질문


    12장. 구성 중앙화
    __기술 요구 사항
    __스프링 클라우드 컨피그 서버 소개
    ____구성 저장소의 저장 유형 선택
    ____클라이언트가 먼저 접속할 서버 결정
    ____구성 보안
    ____구성 서버 API 소개
    __구성 서버 설정
    ____에지 서버에 라우팅 규칙 설정
    ____도커 환경을 위한 구성 서버 설정
    __구성 서버의 클라이언트 설정
    ____연결 정보 구성
    __구성 저장소 구조화
    __스프링 클라우드 컨피그 서버 사용
    ____빌드 및 자동화 테스트 실행
    ____구성 서버 API로 구성 조회
    ____민감한 정보의 암호화 및 해독
    __요약
    __질문


    13장. Resilience4j를 사용한 복원력 개선
    __기술 요구 사항
    __Resilience4j의 복원 메커니즘 소개
    ____서킷 브레이커 소개
    ____시간 제한기 소개
    ____재시도 메커니즘 소개
    __소스 코드에 복원력 메커니즘 추가
    ____프로그래밍 방식으로 지연 및 무작위 오류 추가
    ____서킷 브레이커 및 시간 제한기 추가
    ____재시도 메커니즘 추가
    ____자동 테스트 추가
    __서킷 브레이커 및 재시도 메커니즘 테스트
    ____빌드 및 자동화 테스트 실행
    ____정상적인 요청만 유입될 때 서킷이 닫혀 있는지 확인
    ____문제가 발생했을 때 서킷이 열리는지 확인
    ____서킷 브레이커 다시 닫기
    ____무작위 오류로 재시도 메커니즘 테스트
    __요약
    __질문


    14장. 분산 추적
    __기술 요구 사항
    __스프링 클라우드 슬루스와 집킨을 사용한 분산 추적
    __소스 코드에 분산 추적 추가
    ____빌드 파일에 의존성 추가
    ____스프링 클라우드 슬루스 및 집킨에 대한 구성 추가
    ____도커 컴포즈 파일에 집킨 추가
    __분산 추적 수행
    ____RabbitMQ를 대기열 관리자로 사용해 시스템 환경 시작
    ____정상적인 API 요청 전송
    ____비정상적인 API 요청 전송
    ____비동기 처리를 유발하는 API 요청 전송
    ____RabbitMQ를 통해 집킨으로 전달된 추적 정보 모니터링
    ____카프카를 메시지 브로커로 사용
    __요약
    __질문


    3부. 쿠버네티스를 사용한 경량 마이크로서비스 개발

    15장. 쿠버네티스 소개
    __기술 요구 사항
    __쿠버네티스 개념 소개
    __쿠버네티스 API 객체 소개
    __쿠버네티스 런타임 컴포넌트 소개
    __미니큐브를 사용해 쿠버네티스 클러스터 생성
    ____미니큐브 프로필 사용
    ____쿠버네티스의 CLI 도구인 kubectl 사용
    ____kubectl 콘텍스트 사용
    ____쿠버네티스 클러스터 생성
    __샘플 디플로이먼트 생성
    __로컬 쿠버네티스 클러스터 관리
    ____쿠버네티스 클러스터 중지 및 시작
    ____쿠버네티스 클러스터 종료
    __요약
    __질문


    16장. 쿠버네티스에 마이크로서비스 배포
    __기술 요구 사항
    __넷플릭스 유레카를 쿠버네티스 서비스로 대체
    __쿠버네티스 객체 소개
    __스프링 부트의 지원 기능 사용
    __헬름 소개
    ____헬름 커맨드 실행
    ____헬름 차트의 구조
    ____헬름 템플릿과 전달 값
    ____common 라이브러리 차트
    ____components 차트
    ____environments 차트
    __개발 및 테스트 환경을 위한 쿠버네티스 배포
    ____도커 이미지 빌드
    ____헬름 차트의 의존성 해결
    ____쿠버네티스에 배포
    ____쿠버네티스 환경에 맞게 테스트 스크립트 수정
    ____디플로이먼트 테스트
    __스테이징 및 상용 환경을 위한 쿠버네티스 배포
    ____소스 코드 수정
    ____쿠버네티스에 배포
    ____정리
    __요약
    __질문


    17장. 쿠버네티스로 기존 시스템 환경 대체
    __기술 요구 사항
    __스프링 클라우드 컨피그 서버 대체
    ____스프링 클라우드 컨피그 서버를 대체하기 위한 변경 작업
    __스프링 클라우드 게이트웨이 대체
    ____스프링 클라우드 게이트웨이를 대체하기 위한 변경 작업
    __인증서 프로비저닝 자동화
    __쿠버네티스 컨피그 맵, 시크릿, 인그레스, cert-manager를 사용한 테스트
    ____인증서 갱신
    ____스테이징 및 상용 환경을 위한 쿠버네티스 배포
    __쿠버네티스 없이도 마이크로서비스가 작동하는지 확인
    ____도커 컴포즈 파일의 수정 사항
    ____도커 컴포즈로 테스트
    __요약
    __질문


    18장. 서비스 메시를 사용해 관찰 가능성 및 관리 편의성 개선
    __기술 요구 사항
    __이스티오를 이용한 서비스 메시 소개
    ____이스티오 소개
    ____마이크로서비스에 이스티오 프록시 삽입
    ____이스티오의 API 객체 소개
    __마이크로서비스 환경 단순화
    ____이스티오 인그레스 게이트웨이로 쿠버네티스 인그레스 컨트롤러 대체
    ____이스티오 예거 컴포넌트로 집킨 서버 대체
    __쿠버네티스 클러스터에 이스티오 배포
    ____이스티오 서비스에 대한 접근 설정
    __서비스 메시 생성
    ____소스 코드 변경
    ____커맨드를 실행해 서비스 메시 생성
    __서비스 메시 관찰
    __서비스 메시 보안
    ____HTTPS와 인증서로 외부 엔드포인트 보호
    ____OAuth 2.0/OIDC 접근 토큰을 사용한 외부 요청 인증
    ____상호 인증을 사용한 내부 통신 보호
    __서비스 메시의 복원력 확보
    ____결함을 삽입해 탄력성 테스트
    ____지연을 삽입해 복원력 테스트
    __비가동 시간 없이 업데이트 수행
    ____소스 코드 변경
    ____v1 및 v2 버전의 마이크로서비스 배포
    ____모든 트래픽이 v1 버전의 마이크로서비스로 전달되는지 확인
    ____카나리아 테스트 실행
    ____블루/그린 배포 실행
    __도커 컴포즈로 테스트 실행
    __요약
    __질문


    19장. EFK 스택을 사용한 로깅 중앙화
    __기술 요구 사항
    __플루언티드 소개
    ____플루언티드 개요
    ____플루언티드 구성
    __쿠버네티스에 EFK 스택 배포
    ____마이크로서비스 빌드 및 배포
    ____일래스틱서치와 키바나 배포
    ____플루언티드 배포
    __EFK 스택 실습
    ____키바나 초기화
    ____로그 레코드 분석
    ____마이크로서비스의 로그 레코드 검색
    ____근본 원인 분석 수행
    __요약
    __질문


    20장. 마이크로서비스 모니터링
    __기술 요구 사항
    __프로메테우스와 그라파나를 사용한 성능 모니터링
    __애플리케이션 메트릭 수집을 위한 소스 코드 변경
    __마이크로서비스 빌드 및 배포
    __그라파나 대시보드를 사용한 마이크로서비스 모니터링
    ____테스트용 로컬 메일 서버 설치
    ____부하 테스트 실행
    ____키알리 내장 대시보드 사용
    ____기존 그라파나 대시보드 가져오기
    ____사용자 정의 그라파나 대시보드 개발
    ____그라파나 대시보드 내보내기 및 가져오기
    __그라파나 경고 설정
    ____메일 기반 알림 채널 정의
    ____서킷 브레이커에 경고 설정
    ____서킷 브레이커 경고 테스트
    __요약
    __질문


    21장. 맥OS용 설치 지침
    __기술 요구 사항
    __도구 설치
    ____홈브루 설치
    ____홈브루로 도구 설치
    ____홈브루 없이 도구 설치
    ____설치 후 조처
    ____설치 확인
    __소스 코드 다운로드
    ____IDE 사용
    ____코드 구조


    22장. 윈도우용 설치 지침
    __기술 요구 사항
    __도구 설치
    ____윈도우용 도구 설치
    ____WSL 2 리눅스 서버에 도구 설치
    __소스 코드 다운로드
    ____코드 구조


    23장. 자바 마이크로서비스의 네이티브 컴파일
    __기술 요구 사항
    __자바 소스 코드의 네이티브 컴파일이 필요한 이유
    __그랄VM 프로젝트 소개
    __스프링 네이티브 프로젝트 소개
    __소스 코드를 네이티브 이미지로 컴파일
    ____소스 코드 변경
    ____추적 에이전트 설치
    ____추적 에이전트 실행
    ____네이티브 이미지 생성
    __도커 컴포즈로 테스트
    __쿠버네티스로 테스트
    __요약
    __질문

출판사 서평

◈ 이 책에서 다루는 내용 ◈

◆ 스프링 부트를 사용한 리액티브 마이크로서비스 구축
◆ 스프링 클라우드를 사용해 복원력 및 확장성 있는 마이크로서비스 개발
◆ 스프링 시큐리티 및 OAuth 2.1/OIDC를 사용해 공개 API 보호
◆ 도커를 사용해 개발, 테스트 환경과 상용 환경 사이의 격차 해소
◆ 쿠버네티스를 사용한 마이크로서비스 배포 및 관리
◆ 이스티오를 사용한 보안성, 관찰 가능성, 트래픽 관리 편의성 향상
◆ JUnit, Testcontainers, 그래들(Gradle), 배시(Bash)를 사용해 자동화된 마이크로서비스 테스트 작성 및 실행


◈ 이 책의 대상 독자 ◈

쿠버네티스를 컨테이너 오케스트레이터(container orchestrator)로 사용하고 이스티오를 서비스 메시(service mesh)로 사용해, 기반 마이크로서비스 환경을 구축하고 온프레미스(onpremise)나 클라우드로 배포하는 방법을 배우려는 자바, 스프링 개발자와 아키텍트를 위한 책이다. 마이크로서비스 아키텍처(microservice architecture)에 익숙하지 않더라도 문제없이 읽을 수 있다.


◈ 이 책의 구성 ◈

1장, ‘마이크로서비스 소개’에서는 이 책의 기본 전제인 마이크로서비스의 필수 개념과 디자인 패턴을 설명한다.
2장, ‘스프링 부트 소개’에서는 스프링 부트와 책의 앞부분에서 사용할 오픈소스 프로젝트를 소개한다. RESTful API 개발에 사용하는 스프링 웹플럭스, OpenAPI 기반 API 문서를 생성하는 springdoc-openapi, SQL 및 NoSQL 데이터베이스에 데이터를 저장할 때 사용하는 스프링 데이터, 메시지 기반의 마이크로서비스에서 사용하는 스프링 클라우드 스트림, 마이크로서비스를 컨테이너로 실행하는 도커 등을 소개한다.
3장, ’공조 마이크로서비스 집합’에서는 생성 공조 마이크로서비스 집합을 생성하는 방법을 설명한다. 스프링 이니셜라이저(Spring Initializr)를 사용해 스프링 프레임워크 5.3 및 스프링 부트 2.5 기반의 골격 프로젝트를 생성하고 세 가지 핵심 서비스를 만든다. 또한 세 가지 핵심 서비스에서 얻은 정보를 집계해 복합적 결과를 만드는 복합 서비스도 만든다. 3장의 뒷부분에선 스프링 웹플럭스(Spring WebFlux)를 기반으로 기본적인 RESTful API를 추가하는 방법을 배우며, 4장에서는 더 많은 기능을 마이크로서비스에 추가한다.
4장, ‘도커를 사용한 마이크로서비스 배포’에서는 도커를 사용해 마이크로서비스를 배포하는 방법을 설명한다. Dockerfile이나 docker-compose 파일을 이용해 전체 마이크로서비스 환경을 하나의 커맨드로 시작하는 방법을 배우고, 여러 스프링 프로필을 사용해 도커용 구성과 이외의 구성을 분리해서 처리하는 방법도 살펴본다.
5장, ‘OpenAPI를 사용한 API 문서화’에서는 OpenAPI를 사용해, 마이크로서비스에서 공개하는 API를 빠르게 문서화하는 방법을 배운다. 서비스 코드에 붙인 애노테이션(annotation)을 검사해 OpenAPI 기반의 API 문서를 생성하는 springdoc-openapi와 웹 브라우저에서 API를 테스트하는 스웨거 UI(Swagger UI)를 사용해본다.
6장, ‘영속성 추가’에서는 마이크로서비스 데이터에 영속성을 부여하는 방법을 배운다. 스프링 데이터를 사용해 두 핵심 마이크로서비스의 데이터를 문서 데이터베이스인 MongoDB에 저장 및 접근하게 하고, 나머지 마이크로서비스의 데이터는 관계형 데이터베이스인 MySQL에 두고 접근하게 한다. 통합 테스트를 실행할 때는 Testcontainers를 사용해 데이터베이스를 시작한다.
7장, ‘리액티브 마이크로서비스 개발’에서는 리액티브(reactive) 방식을 사용해야 하는 이유와 사용 시기, 종단 간(end-to-end) 리액티브 서비스를 개발하는 방법을 배운다. 논블로킹(non-blocking) 동기 방식 RESTful API, 이벤트 기반 비동기 방식 서비스를 개발하고 테스트하는 방법도 배운다. 또한 MongoDB용 리액티브 논블로킹 드라이버 사용 방법과 일반적인 MySQL용 블로킹 코드 사용 방법을 배운다.
8장, ‘스프링 클라우드 소개’에서는 이 책에서 사용하는 스프링 클라우드 및 스프링 클라우드 컴포넌트를 소개한다.
9장, ‘넷플릭스 유레카를 사용한 서비스 검색’에서는 스프링 클라우드에 넷플릭스 유레카(Netflix Eureka)를 사용해 서비스 검색 기능을 추가하는 방법을 알아본다. 즉 넷플릭스 유레카 기반의 서비스 검색 서버를 시스템 환경에 추가하고, 스프링 클라우드 로드 밸런서(LoadBalancer)를 사용해 다른 마이크로서비스를 찾도록 마이크로서비스를 구성한다. 또한 자동으로 마이크로서비스를 등록하는 방법과 스프링 클라우드 로드 밸런서를 통해 전달된 트래픽을 활성화된 새 인스턴스로 자동 로드 밸런싱하는 방법을 배운다.
10장, ‘스프링 클라우드 게이트웨이를 에지 서버로 사용’에서는 스프링 클라우드 게이트웨이를 사용해 마이크로서비스를 에지 서버(edge server) 뒤로 숨기고, 골라낸 일부 API만 외부 소비자에게 공개하는 방법을 배운다. 또한 외부 소비자가 볼 수 없도록 마이크로서비스 내부의 복잡성을 숨기는 방법을 살펴본다. 즉 스프링 클라우드 게이트웨이 기반의 에지 서버를 시스템 환경에 추가하고 공개 API만 노출하도록 에지 서버를 구성한다.
11장, ‘API 접근 보안’에서는 OAuth 2.0 및 OpenID Connect를 사용해 공개 API를 보호하는 방법을 설명한다. Spring Authorization Server 기반의 OAuth 2.0 권한 서버를 시스템 환경에 추가하는 방법과 해당 권한 서버에서 발급한 유효한 접근 토큰을 가진 클라이언트만 에지 서버와 복합 서비스에 접근할 수 있도록 구성하는 방법을 배운다. 또한 에지 서버를 통해 권한 부여 서버를 공개하고 HTTPS를 사용해 외부 소비자와의 통신을 보호하는 방법을 알아본다. 마지막으로, 내부 OAuth 2.0 인증 서버를 외부 OpenID Connect 공급자인 Auth0로 교체하는 방법을 배운다.
12장, ‘구성 중앙화’에서는 하나의 중앙 구성 저장소에서 모든 마이크로서비스의 구성 파일을 가져오고, 구성 서버를 사용해 런타임(runtime)에 마이크로서비스로 구성을 배포하는 방법을 배운다. 또한 시스템 환경에 스프링 클라우드 컨피그 서버(Spring Cloud Config Server)를 추가하고 스프링 컨피그 서버(Spring Config Server)에서 구성을 가져오도록 마이크로서비스를 구성하는 방법을 살펴본다.
13장, ‘Resilience4j를 사용한 복원력 개선’에서는 Resilience4j의 기능을 이용해 연쇄 장애(chain of failure) 같은 안티 패턴(anti-pattern)을 방지하는 방법을 설명하며, 복합 서비스에 재시도 메커니즘과 서킷 브레이커(circuit breaker)를 추가하는 방법을 배운다. 서킷이 열려 있을 때 빠른 실패 로직이 작동하도록 서킷 브레이커를 구성하는 방법과 폴백 메서드(fallback method)를 사용해 최적화된 응답을 생성하는 방법도 배운다.
14장, ‘분산 추적’에서는 집킨(Zipkin)을 사용해 추적 정보를 수집하고 시각화하는 방법을 설명한다. 또한 스프링 클라우드 슬루스(Spring Cloud Sleuth)로 요청에 추적 ID를 추가해 공조 마이크로서비스 간의 요청 체인을 시각화하는 방법을 배운다.
15장, ‘쿠버네티스 소개’에서는 쿠버네티스의 핵심 개념과 샘플 디플로이먼트(sample deployment) 생성 방법을 설명한다. 미니큐브(Minikube)를 사용해 개발 및 테스트 용도의 쿠버네티스를 로컬에 설치하는 방법을 배운다.
16장, ‘쿠버네티스에 마이크로서비스 배포’에서는 쿠버네티스에 마이크로서비스를 배포하는 방법을 설명하며, 헬름(Helm)을 사용해 쿠버네티스에 배포할 마이크로서비스를 패키징하고 구성하는 방법을 배운다. 테스트 환경, 상용 환경 등 다양한 런타임 환경에 헬름을 사용해 마이크로서비스를 배포한다. 또한 쿠버네티스 서비스 객체와 kube-proxy 런타임 컴포넌트를 기반으로 하는, 쿠버네티스에 내장된 서비스 검색 기능으로 넷플릭스 유레카를 대체하는 방법을 배운다.
17장, ‘쿠버네티스로 기존 시스템 환경 대체’에서는 앞에서 소개한 스프링 클라우드 서비스를 쿠버네티스 기능으로 대체하는 방법을 설명한다. 스프링 클라우드 컨피그 서버를 쿠버네티스 시크릿과 컨피그맵(ConfigMap)으로 대체하는 이유와 방법을 배운다. 또한 스프링 클라우드 게이트웨이를 쿠버네티스 인그레스(Kubernetes Ingress) 객체로 대체하는 방법과 cert-manager를 사용해 외부 HTTPS 엔드포인트를 위한 인증서를 자동으로 프로비저닝하고 갱신하는 방법을 배운다.
18장, ‘서비스 메시를 사용해 관찰 가능성 및 관리 편의성 개선’에서는 서비스 메시 개념을 소개하고 이스티오를 사용해 쿠버네티스에 서비스 메시를 구현하는 방법을 설명한다. 서비스 메시를 사용해 마이크로서비스 환경의 복원력, 보안, 트래픽 관리, 관찰 가능성을 향상하는 방법을 배운다.
19장, ‘EFK 스택을 사용한 로깅 중앙화’에서는 일래스틱서치(Elasticsearch), 플루언티드(Fluentd), 키바나(Kibana)를 사용해 마이크로서비스의 로그 스트림(log stream)을 수집, 저장, 시각화하는 방법을 설명한다. 미니큐브에 EFK 스택을 배포하는 방법과 EFK 스택으로 수집한 로그 레코드를 분석하는 방법, 여러 마이크로서비스가 관련된 요청을 처리하면서 발생하는 마이크로서비스 로그 출력을 찾는 방법을 배운다. 또한 EFK 스택을 사용해 근본 원인 분석을 수행하는 방법을 알아본다.
20장, ‘마이크로서비스 모니터링’에서는 프로메테우스와 그라파나를 이용해 쿠버네티스에 배포된 마이크로서비스를 모니터링하는 방법을 설명한다. 기존 그라파나 대시보드를 활용해 다양한 유형의 메트릭을 모니터링하는 방법과 직접 대시보드를 만드는 방법을 배운다. 마지막으로, 그라파나에서 특정 메트릭에 임곗값을 구성하고, 이를 초과하면 이메일을 전송하는 경고를 생성하는 방법을 배운다.
21장, ‘맥OS용 설치 지침’에서는 맥OS(MacOS)에 이 책에서 사용하는 도구를 설치하는 방법을 설명한다.
22장, ‘윈도우용 설치 지침’에서는 윈도우 PC에 리눅스용 윈도우 하위 시스템 v2(WSL 2, Windows Subsystem for Linux 2)를 사용해 이 책에서 사용하는 도구를 설치하는 방법을 설명한다.
23장, ‘자바 마이크로서비스의 네이티브 컴파일’에서는 스프링 네이티브(Spring Native) 베타 버전과 그랄VM 네이티브 이미지 컴파일러(GraalVM native-image compiler)를 사용해 스프링 기반 마이크로서비스를 네이티브 코드로 컴파일하는 방법을 설명한다. 자바 VM(Java Virtual Machine) 기반 마이크로서비스보다 시작 속도가 월등히 빠른 마이크로서비스를 생성할 수 있다.

각 장의 말미에는 해당 장에서 다루는 내용을 정리하는 데 도움이 되는 간단한 질문이 몇 개씩 있다. 질문에 대한 답은 깃허브 저장소에 있는 Assessments 파일에 있다.


◈ 옮긴이의 말 ◈

시스템 통합이나 엔터프라이즈 업계에서 일하는 자바 개발자라면 갑작스럽게 밀어닥친 마이크로서비스 열풍과 이를 보조하는 도커, 쿠버네티스 등 컨테이너 기반 환경의 인기에 부담감을 느낄 수밖에 없을 것이다. 좀 더 유연하고 확장성 있는 서비스를 위한 시대적인 요구에 따른 것이라곤 하지만, 개발 자체가 아닌 기반 환경의 변화에 따라 맞닥뜨린 급격한 학습 곡선은 개발자에게 그리 달가운 상황은 아니기 때문이다.
이런 새로운 변화에 따른 학습이 필요하다고 느낀다면 이 책이 좋은 선택이 될 것이다. 개발자와 아키텍트가 편하게 볼 수 있도록 이론과 실습을 적절히 조합했고, 스프링 부트와 스프링 클라우드를 이용해 마이크로서비스를 구축하는 방법을 설명한다. 또한 다양한 오픈소스 도구를 도입해야 하는 이유와 스프링 애플리케이션과의 연동 방법을 친절하게 알려준다. 넓은 범위를 다루지만 각 기술 요소의 소개보다는 소스 코드 중심으로 실무에 필요한 범위에 맞춰 핵심을 전달하는 책이라고 말할 수 있다.

기본정보

상품정보 테이블로 ISBN, 발행(출시)일자 , 쪽수, 크기, 총권수, 시리즈명, 원서(번역서)명/저자명을(를) 나타낸 표입니다.
ISBN 9791161758558
발행(출시)일자 2024년 06월 27일
쪽수 812쪽
크기
187 * 235 * 43 mm / 1573 g
총권수 1권
시리즈명
소프트웨어 아키텍처
원서(번역서)명/저자명 Microservices with Spring Boot and Spring Cloud - Second Edition/Larsson, Magnus

Klover

구매 후 리뷰 작성 시, e교환권 200원 적립

데이터를 불러오는 중입니다.

문장수집 (0)

문장수집 안내
문장수집은 고객님들이 직접 선정한 책의 좋은 문장을 보여주는 교보문고의 새로운 서비스입니다. 마음을 두드린 문장들을 기록하고 좋은 글귀들은 "좋아요“ 하여 모아보세요. 도서 문장과 무관한 내용 등록 시 별도 통보 없이 삭제될 수 있습니다.
리워드 안내
구매 후 90일 이내에 문장수집 작성 시 e교환권 100원을 적립해드립니다.
e교환권은 적립 일로부터 180일 동안 사용 가능합니다. 리워드는 작성 후 다음 날 제공되며, 발송 전 작성 시 발송 완료 후 익일 제공됩니다.
리워드는 한 상품에 최초 1회만 제공됩니다.
주문취소/반품/절판/품절 시 리워드 대상에서 제외됩니다.
판매가 5,000원 미만 상품의 경우 리워드 지급 대상에서 제외됩니다. (2024년 9월 30일부터 적용)

구매 후 리뷰 작성 시, e교환권 100원 적립

이 책의 첫 기록을 남겨주세요.

교환/반품/품절 안내

  • 반품/교환방법

    마이룸 > 주문관리 > 주문/배송내역 > 주문조회 > 반품/교환 신청, [1:1 상담 > 반품/교환/환불] 또는 고객센터 (1544-1900)
    * 오픈마켓, 해외배송 주문, 기프트 주문시 [1:1 상담>반품/교환/환불] 또는 고객센터 (1544-1900)
  • 반품/교환가능 기간

    변심반품의 경우 수령 후 7일 이내,
    상품의 결함 및 계약내용과 다를 경우 문제점 발견 후 30일 이내
  • 반품/교환비용

    변심 혹은 구매착오로 인한 반품/교환은 반송료 고객 부담
  • 반품/교환 불가 사유

    1) 소비자의 책임 있는 사유로 상품 등이 손실 또는 훼손된 경우
    (단지 확인을 위한 포장 훼손은 제외)
    2) 소비자의 사용, 포장 개봉에 의해 상품 등의 가치가 현저히 감소한 경우
    예) 화장품, 식품, 가전제품(악세서리 포함) 등
    3) 복제가 가능한 상품 등의 포장을 훼손한 경우
    예) 음반/DVD/비디오, 소프트웨어, 만화책, 잡지, 영상 화보집
    4) 소비자의 요청에 따라 개별적으로 주문 제작되는 상품의 경우 ((1)해외주문도서)
    5) 디지털 컨텐츠인 ebook, 오디오북 등을 1회이상 ‘다운로드’를 받았거나 '바로보기'로 열람한 경우
    6) 시간의 경과에 의해 재판매가 곤란한 정도로 가치가 현저히 감소한 경우
    7) 전자상거래 등에서의 소비자보호에 관한 법률이 정하는 소비자 청약철회 제한 내용에 해당되는 경우
    8) 세트상품 일부만 반품 불가 (필요시 세트상품 반품 후 낱권 재구매)
    9) 기타 반품 불가 품목 - 잡지, 테이프, 대학입시자료, 사진집, 방통대 교재, 교과서, 만화, 미디어전품목, 악보집, 정부간행물, 지도, 각종 수험서, 적성검사자료, 성경, 사전, 법령집, 지류, 필기구류, 시즌상품, 개봉한 상품 등
  • 상품 품절

    공급사(출판사) 재고 사정에 의해 품절/지연될 수 있으며, 품절 시 관련 사항에 대해서는 이메일과 문자로 안내드리겠습니다.
  • 소비자 피해보상 환불 지연에 따른 배상

    1) 상품의 불량에 의한 교환, A/S, 환불, 품질보증 및 피해보상 등에 관한 사항은 소비자분쟁 해결 기준 (공정거래위원회 고시)에 준하여 처리됨
    2) 대금 환불 및 환불지연에 따른 배상금 지급 조건, 절차 등은 전자상거래 등에서의 소비자 보호에 관한 법률에 따라 처리함

상품 설명에 반품/교환 관련한 안내가 있는 경우 그 내용을 우선으로 합니다. (업체 사정에 따라 달라질 수 있습니다.)

한강 스페셜 에디션
이벤트
  • sam x 한샘 [똑똑한sam]
  • 2025 1학기 대학교재전
01 / 02
TOP