이 책은 쿠버네티스 클러스터의 설계와 관리를 설명한다. 개발자와 데브옵스(DevOps) 엔지니어, 컨테이너 오케스트레이션을 사용해 복잡한 분산 시스템을 개발 및 진화시켜야 하는 개발자를 대상으로 쿠버네티스가 제공하는 모든 기능과 서비스를 다룬다. 또한 다양한 환경과 사용 사례를 고려해 대규모 시스템을 만들고, 쿠버네티스에 배포하는 단계도 자세히 설명한다. 이 책을 통해 쿠버네티스의 구성 방법과 특정 자원의 적절한 사용 시기, 최상의 효율로 클러스터를 구현 및 구성 방법에 대해 깊이 있는 지식을 갖게 될 것이다. 실습과 연습을 통해 쿠버네티스의 구조와 클러스터의 설치, 운영, 업그레이드 방법을 살펴보고, 모범 사례를 이용해 소프트웨어 배포 방법을 자세히 설명한다.
쿠버네티스는 컨테이너 애플리케이션의 배포와 확장, 관리를 자동화하는 오픈소스 시스템이다. 많은 수의 컨테이너를 실행하거나 컨테이너 관리를 자동화할 때 쿠버네티스는 꼭 필요하다. 이 책은 쿠버네티스 클러스터의 고급 관리를 안내하는 데 초점을 맞추고 있다.
이 책은 쿠버네티스 아키텍처의 기초를 설명하고 쿠버네티스의 설계를 자세히 설명한다. 수평적 포드 자동 스케일링, 롤링 업데이트, 리소스 할당량, 영구 스토리지 백업 같은 고급 기능을 비롯해 쿠버네티스에서 복잡한 스테이트풀 마이크로서비스를 실행하는 방법까지 다룬다. 실제 사용 사례에서는 네트워크 구성 옵션을 탐색하고 다양한 쿠버네티스 네트워크 플러그인을 설정, 작동 및 문제를 해결하는 방법을 이해한다. 마지막으로 자동화와 유지 관리 작업 흐름에서 사용자 정의 리소스 개발과 활용에 대해 살펴본다. 이 책에서는 프로메테우스, 역할 기반 액세스 제어, API 집계 같은 쿠버네티스 1.10 릴리스를 기반으로 하는 개념도 다룬다. 이 책을 모두 읽으면 중급에서 고급 수준으로 발전하기 위해 알아야 할 모든 것을 알게 될 것이다.
이 책은 바로 여러분이 기다리던 책이다. 마이크로서비스를 개발하고 쿠버네티스에 배포하는 두 가지 과정을 안내한다. 마이크로서비스 기반 아키텍트와 쿠버네티스의 시너지 효과는 매우 강력하다. 이 책은 모든 각도를 망라하고 있다. 마이크로서비스와 쿠버네티스의 기본 개념을 설명하고, 실제 문제와 장단점을 알아본 후, 척척 만들어지는 마이크로서비스 기반 시스템의 개발 과정을 안내하고 모범 사례와 권장 사항을 제공한다.
엄청난 양의 근거를 아주 깊이 있게 설명하기 위한 작업 코드를 다룬다. 마이크로서비스 기반 아키텍트를 설계하고, 마이크로서비스를 만들고, 만들어진 마이크로서비스를 테스트하고, 도커 이미지로 패키징하는 방법을 알게 될 것이다. 그런 다음 도커 이미지 패키지로 시스템을 쿠버네티스에 배포하며 관리하는 방법을 배우게 될 것이다.
그 과정에서 자동화된 CI/CD, gRPC 기반 마이크로서비스, 서버리스(serverless) 컴퓨팅, 서비스 메시와 같은 중요한 트렌드에 익숙해질 것이다.
끝에서는 쿠버네티스에 배포된 마이크로서비스 기반 아키텍트를 사용해 대규모 클라우드 네이티브 시스템을 계획, 개발, 운영할 수 있는 많은 지식과 실무 경험을 얻게 될 것이다.