본문 바로가기

도서 소개

클라우드 네이티브 스프링 인 액션

 

클라우드 환경에 스프링 애플리케이션을 구축하는 효과적인 방법

 

클라우드 기술이 발달하면서 많은 애플리케이션이 클라우드에서 서비스되고 있다. 이 책에서는 가상의 온라인 서점 시스템을 개발하며 클라우드 환경에 애플리케이션을 어떻게 구축하는지 상세히 설명한다. 스프링으로 클라우드 네이티브 앱을 빌드 및 테스트하고, 도커로 컨테이너화하며, 쿠버네티스로 퍼블릭 클라우드에 배포하는 방법을 배운다. 클라우드 네이티브 환경과 개발 원칙에 대한 이해부터 시작하여 모범 사례와 디자인 패턴을 학습하고, 잘 알려지지 않은 팁과 요령을 배워 문제없이 클라우드 네이티브 개발을 진행하도록 돕는다. 나아가 보안, 복원력, 확장성 처리에 대해 이해하고 지속적 배포와 깃옵스까지 실습해본다. 점점 더 복잡해지는 클라우드 환경을 탐색하는 데 완벽한 입문서가 될 것이다.

 

도서구매 사이트(가나다순)

  [교보문고]  [도서11번가]  [알라딘]  [예스이십사]  [인터파크]  [쿠팡

 

전자책 구매 사이트(가나다순)

  교보문고 / 구글북스 / 리디북스 / 알라딘 / 예스이십사

 

출판사 제이펍
저작권사 Manning
원서명 Cloud Native Spring in Action (9781617298424)
도서명 클라우드 네이티브 스프링 인 액션
부제 스프링 부트와 도커, 쿠버네티스로 애플리케이션 구축하기
지은이 토마스 비탈레
옮긴이 차건회
감수자 (없음)
시리즈 I♥Cloud 27
출판일 2024. 03. 29
페이지 768쪽
판 형 46배판변형(188*245*37)
제 본 무선(soft cover)
정 가 45,000원
ISBN 979-11-92987-67-5 (93000)
키워드 데브옵스, CI/CD, 파이프라인, 컨테이너, 자바, 프레임워크, REST API, 복원력, 통합 가시성, 분산 시스템
분 야 네트워크 / 클라우드


관련 사이트
아마존 도서 페이지
저작권사 도서 페이지

 

관련 시리즈

I♥Cloud 27

 

관련 포스트

■ 2024.03.20 - [출간 전 책 소식] - 서버 구축 없이 사이트를 만드는 방법

 

관련 도서

■ 실전 스프링 부트

■ 모두를 위한 클라우드 컴퓨팅

 

관련 파일 다운로드

■ 예제 파일 깃허브: https://github.com/ThomasVitale/cloud-native-spring-in-action

 

강의 보조 자료(교재로 채택하신 분들은 메일(textbook@jpub.kr)을 보내주시면 다음 자료를 보내드립니다.)
■ 본문의 그림과 표

 

미리보기(옮긴이 머리말, 베타리더 후기, 추천 서문(조시 롱), 머리말, 감사의 글, 이 책에 대하여, 표지에 대하여, 본문 일부)

 

정오표 페이지
https://jpub.tistory.com/1557

 

도서 구매 사이트(가나다순)

  [교보문고]  [도서11번가]  [알라딘]  [예스이십사]  [인터파크]  [쿠팡

 

전자책 구매 사이트(가나다순)

  교보문고 / 구글북스 / 리디북스 / 알라딘 / 예스이십사

 

도서 소개

온라인 서점 시스템을 만들며 배우는 클라우드 네이티브 개발

 

클라우드 네이티브 방식을 이용하면 소프트웨어를 신속하게 제공하고, 필요에 따라 동적으로 확장하며, 비용을 최적화하면서 항상 사용 가능하게 유지할 수 있다. 개발자가 최상의 결과를 얻기 위해 고려해야 할 ‘15요소 방법론’을 기초로 클라우드 네이티브 애플리케이션을 개발하고 운영하는 거의 모든 방법을 이 책에 담았다. 스프링 부트와 쿠버네티스를 사용해 클라우드 네이티브 애플리케이션을 설계부터 빌드, 배포까지 모두 배울 수 있는 유익한 도서다.

 

‘폴라 북숍’이라는 가상의 온라인 서점 시스템을 개발하면서 스프링 및 자바 생태계에서 제공하는 라이브러리를 사용해 클라우드 네이티브 애플리케이션을 빌드하고 테스트하는 방법을 설명한다. 아이디어를 떠올리는 것을 시작으로 모든 과정을 단계별로 안내하고 있어 클라우드 네이티브 개발이 어떤 사이클로 이루어지는지 살펴볼 수 있다. 특히 REST API, 데이터 지속성, 리액티브 프로그래밍, API 게이트웨이, 함수, 이벤트 중심 아키텍처, 복원력, 보안, 테스트, 통합 가시성 등의 주제를 깊이 다루며 독자로 하여금 처음부터 끝까지 실습하도록 구성한 것이 장점이다. 끝으로 처음부터 만든 클라우드용 애플리케이션을 컨테이너 이미지로 패키징하고 쿠버네티스와 같은 클라우드 환경에 배포하는 방법까지 설명하며 대단원의 막을 내린다.

 

저자는 이 책을 구성하고 집필할 때 “예제는 일상 업무와 관련 있고 즉시 적용할 수 있는 실제적인 것이어야 한다”는 점을 원칙으로 삼았다고 밝혔다. 실전과 같은 예제를 차근차근 따라 하면서 현장에서 바로 쓸 수 있는 기술과 아이디어를 얻길 바란다.

 

주요 내용

  • 스프링으로 클라우드 네이티브 패턴 구현
  • 클라우드 네이티브 모범 사례 및 디자인 패턴
  • 온라인 서점 시스템 개발 실습
  • 필수 및 반응형 애플리케이션 빌드 및 테스트
  • 보안, 복원력 및 확장성 처리
  • 쿠버네티스에서 애플리케이션 구성, 배포 및 통합 가시성
  • 지속적 배포 및 깃옵스 도입

지은이 소개

토마스 비탈레(Thomas Vitale)

복원력 있고 안전한 클라우드 네이티브 엔터프라이즈 애플리케이션 구축을 전문으로 하는 소프트웨어 엔지니어이자 아키텍트다. 덴마크의 Systematic에서 소프트웨어 설루션의 설계 및 개발을 담당하고 있으며, 개발자 경험과 보안에 중점을 두고 클라우드 네이티브 환경을 위한 플랫폼 및 애플리케이션 현대화 작업을 해왔다. 주요 관심사 및 전문 분야는 자바, 스프링 부트, 쿠버네티스, 케이네이티브 및 클라우드 네이티브 기술 전반이다. 지속적 전달 관행을 지지하며 함께 협력하는 협업 문화를 통해 사용자, 고객, 비즈니스에 가치를 제공할 수 있다고 믿고 있으며, 스프링 보안 및 스프링 클라우드와 같은 오픈소스 프로젝트에 기여하고 커뮤니티에서 지식을 나누는 것도 좋아한다.

 

옮긴이 소개

차건회

현재 미국 로스앤젤레스에 있는 Shell Recharge Solutions에서 자바 백엔드 테크 리드로 일하고 있다. 자바, 스프링 부트, 메시지 큐, 일래스틱서치, 레디스 등 자바 백엔드의 전반적인 기술 스택 및 성능 향상에 관심이 있다. 옮긴 책으로는 《크리에이티브 프로그래머》(한빛미디어, 2023), 《좋은 코드, 나쁜 코드》, 《프로그래머의 뇌》(이상 제이펍, 2022)가 있다.

 

차례

옮긴이 머리말 xv

베타리더 후기 xviii

추천 서문(조시 롱) xx

머리말 xxii

감사의 글 xxiv

이 책에 대하여 xxvi

표지에 대하여 xxxii

 

PART I 클라우드 네이티브 개요
CHAPTER 1 클라우드 네이티브 소개 3

1.1 클라우드 네이티브란 무엇인가? 5

__1.1.1 클라우드 네이티브에서의 세 가지 P 5

1.2 클라우드와 클라우드 컴퓨팅 모델 6

__1.2.1 서비스형 인프라스트럭처 9 / 1.2.2 서비스형 컨테이너 9 / 1.2.3 서비스형 플랫폼 10 / 1.2.4 서비스형 함수 10 / 1.2.5 서비스형 소프트웨어 11

1.3 클라우드 네이티브 애플리케이션의 특성 11

__1.3.1 확장성 12 / 1.3.2 느슨한 결합 13 / 1.3.3 복원력 15 / 1.3.4 관측 가능성 16 / 1.3.5 관리 용이성 17

1.4 클라우드 네이티브를 지원하는 문화 및 관행 18

__1.4.1 자동화 19 / 1.4.2 지속적 전달 21 / 1.4.3 데브옵스 22

1.5 클라우드가 최선의 선택인가? 24

__1.5.1 속도 25 / 1.5.2 복원력 26 / 1.5.3 확장성 27 / 1.5.4 비용 27

더보기

1.6 클라우드 네이티브 구성 28

__1.6.1 컨테이너 29 / 1.6.2 오케스트레이션 32 / 1.6.3 서버리스 33

1.7 클라우드 네이티브 애플리케이션을 위한 아키텍처 35

__1.7.1 다중 계층에서 마이크로서비스 아키텍처까지 그리고 그 이후 36 / 1.7.2 클라우드 네이티브 애플리케이션을 위한 서비스 기반 아키텍처 38

요약 40

 

CHAPTER 2 클라우드 네이티브 패턴 및 기술 42

2.1 클라우드 네이티브 개발 원칙: 12요소와 확장 43

__2.1.1 하나의 코드베이스, 하나의 애플리케이션 44 / 2.1.2 API 우선 44 / 2.1.3 의존성 관리 44 / 2.1.4 설계, 빌드, 릴리스, 실행 45 / 2.1.5 설정, 크리덴셜 및 코드 45 / 2.1.6 로그 46 / 2.1.7 일회성 46 / 2.1.8 지원 서비스 47 / 2.1.9 환경 동일성 47 / 2.1.10 관리 프로세스 47 / 2.1.11 포트 바인딩 48 / 2.1.12 상태를 갖지 않는 프로세스 48 / 2.1.13 동시성 49 / 2.1.14 원격 측정 49 / 2.1.15 인증 및 승인 49

2.2 스프링을 사용한 클라우드 네이티브 애플리케이션 구축 50

__2.2.1 스프링 개요 50 / 2.2.2 스프링 부트 애플리케이션 구축 51

2.3 도커를 통한 애플리케이션 컨테이너화 62

__2.3.1 도커 소개: 이미지 및 컨테이너 63 / 2.3.2 컨테이너를 통한 스프링 애플리케이션의 실행 66

2.4 쿠버네티스로 컨테이너 관리 68

__2.4.1 쿠버네티스 소개: 배포, 파드, 서비스 69 / 2.4.2 쿠버네티스에서 스프링 애플리케이션 실행 71

2.5 폴라 북숍: 클라우드 네이티브 애플리케이션 75

__2.5.1 시스템 요구 사항 이해 75 / 2.5.2 프로젝트에서 사용되는 패턴과 기술 78

요약 82

 

PART II 클라우드 네이티브 개발
CHAPTER 3 클라우드 네이티브 개발 시작 87

3.1 클라우드 네이티브 프로젝트 부트스트래핑 88

__3.1.1 하나의 코드베이스, 하나의 애플리케이션 88 / 3.1.2 그래들과 메이븐의 의존성 관리 90

3.2 임베디드 서버로 작업 92

__3.2.1 실행 가능한 JAR 및 임베디드 서버 93 / 3.2.2 요청당 스레드 모델 이해 95 / 3.2.3 내장 톰캣 설정 97

3.3 스프링 MVC를 이용한 RESTful 애플리케이션 구축 100

__3.3.1 REST API를 먼저, 비즈니스 로직은 그다음 100 / 3.3.2 스프링 MVC를 이용한 REST API 구현 106 / 3.3.3 데이터 유효성 검사 및 오류 처리 109 / 3.3.4 미래 요구 사항을 위해 진화하는 API 114

3.4 스프링 RESTful 애플리케이션 테스트 115

__3.4.1 JUnit 5를 이용한 단위 테스트 117 / 3.4.2 @SpringBootTest를 통한 통합 테스트 119 / 3.4.3 @WebMvcTest를 사용한 REST 컨트롤러의 테스트 122 / 3.4.4 @JsonTest를 사용한 JSON 직렬화 테스트 124

3.5 배포 파이프라인: 빌드 및 테스트 126

__3.5.1 배포 파이프라인의 커밋 단계 이해 127 / 3.5.2 깃허브 액션을 이용한 커밋 단계 구현 129

요약 133

 

CHAPTER 4 외부화 설정 관리 136

4.1 스프링 설정 : 속성과 프로파일 139

__4.1.1 속성: 설정을 위한 키-값 쌍 140 / 4.1.2 프로파일: 기능 플래그와 설정 그룹 146

4.2 외부화된 구성: 하나의 빌드, 여러 설정 150

__4.2.1 커맨드라인 인수를 통한 애플리케이션 설정 152 / 4.2.2 JVM 시스템 속성을 통해 애플리케이션 구성 152 / 4.2.3 환경 변수를 통해 애플리케이션 구성 153

4.3 스프링 클라우드 컨피그 서버로 중앙식 설정 관리하기 155

__4.3.1 깃을 통한 설정 데이터 저장 158 / 4.3.2 설정 서버 구성 160 / 4.3.3 복원력 높은 설정 서버 생성 164 / 4.3.4 설정 서버 REST API 이해 166

4.4 스프링 클라우드 컨피그 클라이언트로 설정 서버 사용 168

__4.4.1 설정 클라이언트 구축 168 / 4.4.2 내결함성이 높은 설정 클라이언트의 구축 171 / 4.4.3 런타임 시 설정 새로고침 173

요약 176

 

CHAPTER 5 클라우드에서 데이터 저장과 관리 178

5.1 클라우드 네이티브 시스템을 위한 데이터베이스 179

__5.1.1 클라우드에서의 데이터 서비스 180 / 5.1.2 PostgreSQL을 컨테이너로 실행 183

5.2 스프링 데이터에 대한 데이터 지속성 JDBC 185

__5.2.1 JDBC로 데이터베이스에 연결 187 / 5.2.1 스프링 데이터를 통한 지속성 엔티티 정의 190 / 5.2.3 JDBC 감사 활성화와 설정 195 / 5.2.4 스프링 데이터의 데이터 리포지터리 198

5.3 스프링 및 테스트컨테이너로 데이터 지속성 테스트하기 202

__5.3.1 PostgreSQL을 위한 테스트컨테이너 설정 203 / 5.3.2 @DataJdbcTest 및 테스트컨테이너를 통한 데이터 지속성 테스트 205 / 5.3.3 @SpringBootTest 및 테스트컨테이너를 이용한 통합 테스트 206

5.4 플라이웨이를 통한 프로덕션 환경에서의 데이터베이스 관리 207

__5.4.1 플라이웨이 이해: 데이터베이스 버전 관리 208 / 5.4.2 플라이웨이를 이용한 데이터베이스 스키마 초기화 210 / 5.4.3 플라이웨이를 이용한 데이터베이스 진화 211

요약 213

 

CHAPTER 6 스프링 부트 컨테이너화 215

6.1 도커에서 컨테이너 이미지로 작업하기 216

__6.1.1 컨테이너 이미지 이해 217 / 6.1.2 도커파일을 통한 이미지 생성 218 / 6.1.3 깃허브 컨테이너 저장소로 이미지 저장 222

6.2 스프링 부트 애플리케이션을 컨테이너 이미지로 패키지 226

__6.2.1 스프링 부트의 컨테이너화를 위한 준비 226 / 6.2.2 도커파일로 스프링 부트 컨테이너화 229 / 6.2.3 프로덕션을 위한 컨테이너 이미지 빌드 231 / 6.2.4 클라우드 네이티브 빌드팩을 이용한 스프링 부트 컨테이너화 237

6.3 도커 컴포즈를 통한 스프링 부트 컨테이너의 관리 242

__6.3.1 도커 컴포즈를 통한 컨테이너 라이프사이클 관리 243 / 6.3.2 스프링 부트 컨테이너 디버깅 244

6.4 배포 파이프라인: 패키지 및 등록 247

__6.4.1 커밋 단계에서 릴리스 후보 빌드 248 / 6.4.2 깃허브 액션을 통한 컨테이너 이미지 등록 249

요약 254

 

CHAPTER 7 스프링 부트를 위한 쿠버네티스 기초 256

7.1 도커에서 쿠버네티스로의 이동 257

__7.1.1 로컬 쿠버네티스 클러스터 259 / 7.1.2 로컬 클러스터에서 데이터 서비스 관리 261

7.2 스프링 부트를 위한 쿠버네티스 배포 263

__7.2.1 컨테이너에서 파드로 263 / 7.2.2 배포를 통한 파드 제어 264 / 7.2.3 스프링 부트 애플리케이션을 위한 배포 객체 생성 265

7.3 서비스 검색 및 부하 분산 271

__7.3.1 서비스 검색 및 부하 분산의 이해 271 / 7.3.2 클라이언트 측 서비스 검색 및 부하 분산 272 / 7.3.3 서버 측 서비스 검색 및 부하 분산 274 / 7.3.4 쿠버네티스 서비스를 통한 스프링 부트 애플리케이션 노출 276

7.4 확장성과 일회성 279

__7.4.1 일회성을 위한 조건: 빠른 시작 280 / 7.4.2 일회성을 위한 조건: 우아한 종료 280 / 7.4.3 스프링 부트 애플리케이션 확장 283

7.5 틸트를 사용한 로컬 쿠버네티스 개발 286

__7.5.1 틸트를 사용한 내부 개발 루프 286 / 7.5.2 옥탄트를 사용한 쿠버네티스 워크로드 시각화 289

7.6 배포 파이프라인: 쿠버네티스 매니페스트 유효성 검사 292

__7.6.1 커밋 단계에서 쿠버네티스 매니페스트 검증 292 / 7.6.2 깃허브 액션을 통한 쿠버네티스 매니페스트 유효성 검사 자동화 294

요약 295

 

PART III 클라우드 네이티브 분산 시스템
CHAPTER 8 리액티브 스프링: 복원력과 확장성 299

8.1 리액터와 스프링의 비동기 및 비차단 아키텍처 301

__8.1.1 요청당 스레드에서 이벤트 루프로 302 / 8.1.2 프로젝트 리액터: 모노와 플럭스를 갖는 리액티브 스트림 304 / 8.1.3 스프링 리액티브 스택 이해 306

8.2 스프링 웹플럭스와 스프링 데이터 R2DBC를 갖는 리액티브 서버 307

__8.2.1 스프링 부트를 통한 리액티브 애플리케이션 부트스트래핑 309 / 8.2.2 스프링 데이터 R2DBC를 사용한 리액티브 데이터 지속성 311 / 8.2.3 리액티브 스트림을 이용한 비즈니스 로직 구현 318 / 8.2.4 스프링 웹플럭스로 REST API 노출 321

8.3 스프링 웹 클라이언트를 사용한 리액티브 클라이언트 323

__8.3.1 스프링에서 서비스 간 통신 324 / 8.3.2 데이터 교환 방법에 대한 이해 326 / 8.3.3 웹 클라이언트를 통한 REST 클라이언트 구현 328

8.4 리액티브 스프링을 통한 복원력 높은 애플리케이션 332

__8.4.1 타임아웃 332 / 8.4.2 재시도 336 / 8.4.3 폴백 및 오류 처리 339

8.5 스프링, 리액터, 테스트컨테이너를 이용한 리액티브 애플리케이션의 테스트 341

__8.5.1 모의 웹 서버로 REST 클라이언트 테스트 341 / 8.5.2 @DataR2dbcTest 및 테스트컨테이너를 이용한 데이터 지속성 테스트 344 / 8.5.3 @WebFluxTest를 이용한 REST 컨트롤러 테스트 346

요약 348

 

CHAPTER 9 API 게이트웨이와 서킷 브레이커 350

9.1 에지 서버와 스프링 클라우드 게이트웨이 352

__9.1.1 스프링 클라우드 게이트웨이를 이용한 에지 서버 부트스트래핑 354 / 9.1.2 경로와 술어의 정의 356 / 9.1.3 필터를 통한 요청 및 응답 처리 360

9.2 스프링 클라우드 서킷 브레이커와 Resilience4J로 내결함성 개선하기 362

__9.2.1 스프링 클라우드 서킷 브레이커를 통한 서킷 브레이커 소개 364 / 9.2.2 Resilience4J 서킷 브레이커 설정 365 / 9.2.3 스프링 웹플럭스를 이용한 폴백 REST API 정의 366 / 9.2.4 서킷 브레이커, 재시도 및 시간 제한의 결합 367

9.3 스프링 클라우드 게이트웨이와 레디스를 통한 요청 사용률 제한 371

__9.3.1 레디스 컨테이너 실행 372 / 9.3.2 스프링과 레디스의 통합 373 / 9.3.3 요청 사용률 제한 설정 374

9.4 레디스를 통한 분산 세션 관리 377

__9.4.1 스프링 세션 데이터 레디스를 통한 세션 처리 378

9.5 쿠버네티스 인그레스를 통한 외부 액세스 관리 382

__9.5.1 인그레스 API와 인그레스 컨트롤러 이해 382 / 9.5.2 인그레스 객체 사용 385

요약 388

 

CHAPTER 10 이벤트 중심 애플리케이션과 함수 390

10.1 이벤트 중심 아키텍처 392

__10.1.1 이벤트 중심 모델 이해 392 / 10.1.2 발행자/구독자 모델의 사용 393

10.2 메시지 브로커와 래빗MQ 395

__10.2.1 메시징 시스템의 AMQP 이해 396 / 10.2.2 발행/구독 통신을 위한 래빗MQ 사용 397

10.3 스프링 클라우드 함수를 통한 함수 399

__10.3.1 스프링 클라우드 함수의 함수적 패러다임 사용 400 / 10.3.2 함수의 합성 및 통합: REST, 서버리스, 데이터 스트림 406 / 10.3.3 @FunctionalSpringBootTest를 통한 통합 테스트 408

10.4 스프링 클라우드 스트림을 통한 메시지 처리 410

__10.4.1 래빗MQ와의 통합 설정 410 / 10.4.2 함수의 메시지 채널 바인딩 412 / 10.4.3 테스트 바인더를 통한 통합 테스트 419 / 10.4.4 실패에 대한 메시지 복원력 422

10.5 스프링 클라우드 스트림을 통한 메시지 생성 및 소비 423

__10.5.1 이벤트 소비자 구현 및 멱등성 문제 423 / 10.5.2 이벤트 생성자 구현과 원자성 문제 427

요약 433

 

CHAPTER 11 보안: 인증과 SPA 435

11.1 스프링 보안 기초 436

11.2 키클록을 통한 사용자 계정 관리 441

__11.2.1 보안 영역 정의 443 / 11.2.2 사용자 및 역할 관리 444

11.3 오픈ID 커넥트, JWT 및 키클록을 통한 인증 445

__11.3.1 오픈ID 커넥트를 통한 사용자 인증 446 / 11.3.2 JWT를 통한 사용자 정보 교환 450 / 11.3.3 키클록에서 애플리케이션 등록 452

11.4 스프링 보안 및 오픈ID 커넥트로 사용자 인증 455

__11.4.1 새 의존성 추가 456 / 11.4.2 스프링 보안과 키클록의 통합 설정 457 / 11.4.3 기초적인 스프링 보안 설정 458 / 11.4.4 인증된 사용자 콘텍스트 검사 460 / 11.4.5 스프링 보안 및 키클록에서 사용자 로그아웃 설정 464

11.5 스프링 보안과 SPA 통합 468

__11.5.1 앵귤러 애플리케이션 실행 469 / 11.5.2 인증 흐름 제어 471 / 11.5.3 사이트 간 요청 위조 방지 474

11.6 스프링 보안 및 오픈ID 커넥트 테스트 477

__11.6.1 OIDC 인증 테스트 477 / 11.6.2 CSRF 테스트 479

요약 482

 

CHAPTER 12 보안: 권한과 감사 484

12.1 스프링 클라우드 게이트웨이와 OAuth2를 통한 권한과 역할 485

__12.1.1 스프링 클라우드 게이트웨이에서 다른 서비스로의 토큰 전달 488 / 12.1.2 토큰 사용자 지정 및 사용자 역할 전파 491

12.2 스프링 보안 및 OAuth2를 통한 API 보호(명령형) 497

__12.2.1 스프링 부트 OAuth2 리소스 서버 보호 497 / 12.2.2 스프링 보안 및 JWT를 통한 역할 기반 접근 제어 501 / 12.2.3 스프링 보안 및 테스트컨테이너를 이용한 OAuth2 테스트 504

12.3 스프링 보안과 OAuth2를 이용한 API 보호(반응형) 511

__12.3.1 스프링 부트 OAuth2 리소스 서버 보호 511 / 12.3.2 스프링 보안 및 테스트컨테이너로 OAuth2 테스트 514

12.4 스프링 보안 및 스프링 데이터로 데이터 보호 및 감사 516

__12.4.1 스프링 보안 및 스프링 데이터 JDBC를 사용한 데이터 감사 517 / 12.4.2 스프링 데이터와 @WithMockUser를 통한 데이터 감사 테스트 520 / 12.4.3 스프링 보안 및 스프링 데이터 R2DBC로 사용자 데이터 보호 522 / 12.4.4 @WithMockUser 및 스프링 데이터 R2DBC를 통한 데이터 감사 및 보호 테스트 526

요약 528

 

PART IV 프로덕션에서의 클라우드 네이티브CHAPTER 13 관측 가능성 및 모니터링 533

13.1 스프링 부트, 로키 및 플루언트 비트를 사용한 로깅 534

__13.1.1 스프링 부트를 사용한 로깅 535 / 13.1.2 로키, 플루언트 비트, 그라파나로 로그 관리하기 538

13.2 스프링 부트 액추에이터와 쿠버네티스를 사용한 상태 프로브 544

__13.2.1 액추에이터를 통한 스프링 부트 애플리케이션 상태 프로브 정의 545 / 13.2.2 스프링 부트 및 쿠버네티스에서 상태 프로브 설정 548

13.3 스프링 부트 액추에이터, 프로메테우스, 그라파나를 통한 메트릭 및 모니터링 553

__13.3.1 스프링 부트 액추에이터 및 마이크로미터로 메트릭 설정 554 / 13.3.2 프로메테우스와 그라파나를 통한 메트릭 모니터링 557 / 13.3.3 쿠버네티스에서 프로메테우스 메트릭 설정 562

13.4 오픈텔레메트리 및 템포를 사용한 분산 추적 563

__13.4.1 템포와 그라파나를 통한 트레이스 관리 566 / 13.4.2 오픈텔레메트리를 사용해 스프링 부트에서 추적 구성하기 567

13.5 스프링 부트 액추에이터를 통한 애플리케이션 관리 및 모니터링 572

__13.5.1 스프링 부트에서 플라이웨이 마이그레이션 모니터링 573 / 13.5.2 애플리케이션 정보 노출 574 / 13.5.3 힙 덤프 생성 및 분석 577

요약 579

 

CHAPTER 14 설정과 시크릿 관리 581

14.1 쿠버네티스에서 애플리케이션 설정하기 582

__14.1.1 스프링 시큐리티를 통한 설정 서버 보안 583 / 14.1.2 스프링 클라우드 버스를 통한 런타임 설정 새로고침 584 / 14.1.3 스프링 클라우드 컨피그를 통한 시크릿 관리 586 / 14.1.4 스프링 클라우드 컨피그 비활성화 587

14.2 쿠버네티스에서 컨피그맵과 시크릿 사용 588

__14.2.1 컨피그맵을 통한 스프링 부트 설정 589 / 14.2.2 시크릿으로 민감한 정보를 저장하거나 저장하지 않기 594 / 14.2.3 스프링 클라우드 쿠버네티스를 통한 런타임 설정 갱신 597

14.3 커스터마이즈를 통한 설정 관리 600

__14.3.1 커스터마이즈를 통한 스프링 부트 애플리케이션 관리 및 설정 601 / 14.3.2 커스터마이즈를 통한 여러 환경에 대한 쿠버네티스 설정 관리 606 / 14.3.3 스테이징을 위한 설정 오버레이 정의 609 / 14.3.4 환경 변수 사용자 지정 변경 610 / 14.3.5 컨피그맵 사용자 정의 변경 612 / 14.3.6 이미지 이름 및 버전의 사용자 지정 변경 613 / 14.3.7 복제본 수 사용자 지정 변경 614

요약 618

 

CHAPTER 15 지속적 전달과 깃옵스 620

15.1 배포 파이프라인: 수락 단계 621

__15.1.1 지속적 배포를 위한 릴리스 후보 버전 지정 621 / 15.1.2 배포 파이프라인 수락 단계의 이해 626 / 15.1.3 깃허브 액션으로 수락 단계 구현 628

15.2 프로덕션을 위한 스프링 부트 설정 631

__15.2.1 프로덕션을 위한 설정 오버레이 정의 632 / 15.2.2 스프링 부트 컨테이너 CPU 및 메모리 설정 638 / 15.2.3 프로덕션 환경에 스프링 부트 배포 644

15.3 배포 파이프라인: 프로덕션 단계 646

__15.3.1 배포 파이프라인의 프로덕션 단계 이해 647 / 15.3.2 깃허브 액션을 통한 프로덕션 단계 구현 647

15.4 깃옵스를 사용한 지속적 배포 654

__15.4.1 아르고 CD로 깃옵스 구현 656 / 15.4.2 종합하기 660

요약 662

 

CHAPTER 16 서버리스, 그랄VM 및 케이네이티브 664

16.1 스프링 네이티브 및 그랄VM을 사용한 네이티브 이미지 665

__16.1.1 그랄VM과 네이티브 이미지 이해하기 666 / 16.1.2 스프링 네이티브를 통한 그랄VM의 스프링 부트 지원 667 / 16.1.3 스프링 부트 애플리케이션의 네이티브 이미지 컴파일 674

16.2 스프링 클라우드 함수를 사용한 서버리스 애플리케이션 678

__16.2.1 스프링 클라우드 함수를 통한 서버리스 애플리케이션 구축 679 / 16.2.2 배포 파이프라인: 빌드 및 등록 685 / 16.2.3 서버리스 애플리케이션의 클라우드 배포 687

16.3 케이네이티브를 통한 서버리스 애플리케이션 배포 688

__16.3.1 로컬 케이네이티브 플랫폼 구축 689 / 16.3.2 케이네이티브 CLI로 애플리케이션 배포 690 / 16.3.3 케이네이티브 매니페스트를 통한 애플리케이션 배포 692

요약 696

 

APPENDIX 부록

APPENDIX A 개발 환경 설정 701

A.1 자바 701

A.2 도커 703

A.3 쿠버네티스 705

A.4 다른 툴 707

 

APPENDIX B 디지털오션 프로덕션 환경을 위한 쿠버네티스 710

B.1 디지털오션에서 쿠버네티스 클러스터 실행 711

B.2 디지털오션에서 PostgresQL 데이터베이스 실행 715

B.3 디지털오션에서 레디스 실행 717

B.4 쿠버네티스 오퍼레이터를 통한 래빗MQ 실행 719

B.5 헬름 차트를 사용한 키클록 실행 720

B.6 폴라 UI 실행 723

B.7 모든 클라우드 리소스 삭제 723

 

찾아보기 725

제이펍 소식 더 보기(제이펍의 소통 채널에서 더욱 다양한 소식을 확인하세요!)

  포스트  유튜브  인스타그램  트위터  페이스북