로그인회원가입장바구니고객센터마이페이지회사소개
kangcom
전체
Home >   >   > 
(예약도서)

『Kubernetes in Action: 그림과 상세한 설명을 통한 쿠버네티스 완벽 이해』

   
지은이 마르코 룩샤   |   출판사 에이콘  |   발행일 2018년 12월 17일
 
클릭하시면 큰 도서이미지를 보실 수 있습니다.
판매가 45,000원40,500원 10%
마일리지 5% 2,250원
발행일 2018-12-17
ISBN 1161752242 | 9791161752242
기타정보 번역서 | 808쪽
예상출고일
배송비 무료배송
   
일반
   
예약판매 조기 도서입고시 예약판매가 마감되거나 출판사 사정에 의해 배송일자가 변경될 수 있습니다.
예약 마감일 : 2018년 121724시 ㅣ 출고 예정일 : 2018년 1218
판매권수제한 : 없음
주의사항 입고 다음날 (근무일기준)
 

★ 요약 ★



쿠버네티스를 이용해 애플리케이션을 효과적으로 개발하고 운영할 수 있는 방법을 초보자들도 쉽게 이해할 수 있도록 설명한다. 쿠버네티스 아키텍처 및 각 객체에 대한 개념을 명확히 정립할 수 있도록 예제와 그림을 곁들였다. 후반부에는 쿠버네티스의 내부 구조 및 동작 원리에 대해서도 쉽게 설명하고 있어 쿠버네티스의 안과 밖을 모두 살필 수 있다. 쿠버네티스를 더 깊이 알고자 하는 독자에게 최고의 참고서이자 바이블이 될 것이다.





★ 이 책에서 다루는 내용 ★



■ 쿠버네티스 내부 구조

■ 클러스터상에서 컨테이너 배포

■ 클러스터 보안

■ 무중단 애플리케이션 업데이트





★ 이 책의 대상 독자 ★



주로 애플리케이션 개발자를 대상으로 하며, 운영면에서 필요한 애플리케이션 관리도 대략적으로 설명한다. 이것은 단일 서버 이상의 컨테이너화된 애플리케이션을 실행하고 관리하는 데 관심이 있는 모든 사람에게 적합하다는 의미다.

컨테이너 기술을 배우고 여러 관련 컨테이너를 규모에 맞게 조율하고 싶은 입문자와 전문 소프트웨어 엔지니어라면 쿠버네티스 환경에서 애플리케이션을 개발하고 최적화하고 실행하는 데 필요한 전문 지식을 배울 수 있다.

컨테이너 기술이나 쿠버네티스 관련 경험은 필요하지 않다. 주제를 점진적으로 설명하고 비전문가인 개발자가 이해하기 어려운 애플리케이션 소스 코드는 사용하지 않는다. 하지만 프로그래밍과 컴퓨터 네트워킹, 리눅스를 실행하는 기본 명령 정도는 알고 있어야 하며, HTTP처럼 잘 알려진 컴퓨터 프로토콜도 이해하고 있어야 한다.





★ 이 책의 구성 ★



이 책은 18개의 장을 세 개의 부로 나눠서 설명한다.



1부에서는 도커와 쿠버네티스를 간략하게 소개하고, 쿠버네티스 클러스터를 설정하는 방법과 간단한 애플리케이션 실행 방법을 설명한다. 1부에는 두 개의 장이 있다.

1장, ‘쿠버네티스 소개’에서는 쿠버네티스가 무엇인지, 어떻게 여기까지 오게 됐는지, 오늘날의 대규모 애플리케이션 관리 문제를 해결하는 데 도움이 되는 방법에 대해 설명한다.

2장, ‘도커와 쿠버네티스의 첫걸음’에서는 컨테이너 이미지를 작성하고 쿠버네티스 클러스터에서 실행하는 방법을 설명한다. 또한 클라우드에서 로컬 단일 노드 쿠버네티스 클러스터와 적절한 다중 노드 클러스터를 실행하는 방법도 설명한다.



2부에서는 쿠버네티스에서 애플리케이션을 실행하려면 반드시 알아야 하는 핵심 개념을 소개한다. 각 장은 다음과 같다.

3장 ‘포드: 쿠버네티스에서 컨테이너 실행하기’에서는 쿠버네티스의 기본 구성 블록(포드)을 소개하고 포드 및 기타 쿠버네티스 객체를 라벨로 구성하는 방법을 설명한다.

4장, ‘리플리케이션 및 기타 컨트롤러: 관리되는 포드 배포’에서는 쿠버네티스가 자동으로 컨테이너를 다시 시작해 애플리케이션을 정상으로 유지하는 방법을 설명한다. 또한 관리 포드를 올바르게 실행하고 수평으로 확장하며 클러스터 노드의 장애에 내성을 높이고 향후 사전 정의된 시간에 또는 주기적으로 실행하는 방법을 알아본다.

5장, ‘서비스: 클라이언트가 포드를 검색하고 대화를 가능하게 함’에서는 포드가 클러스터 내부 및 외부에서 실행되는 클라이언트에 제공하는 서비스를 어떻게 표현할 수 있는지 알려준다. 또한 클러스터에서 실행 중인 포드가 클러스터 내/외부에 상관없이 서비스를 검색하고 액세스하는 방법을 보여 준다.

6장, ‘볼륨: 컨테이너에 디스크 스토리지 연결하기’에서는 동일한 포드에서 실행 중인 여러 컨테이너가 파일을 공유하는 방법과 영구 스토리지를 관리하고 포드에 액세스할 수 있게 하는 방법을 설명한다.

7장, ‘ConfigMaps와 Secrets: 애플리케이션 설정하기’에서는 설정 데이터와 자격 증명과 같은 중요한 정보를 포드 내부에서 실행되는 애플리케이션에 전달하는 방법을 보여준다.

8장, 애플리케이션에서 포드 메타데이터 및 기타 리소스에 접근하기’에서는 애플리케이션이 실행중인 쿠버네티스 환경에 대한 정보를 알아내는 방법과 쿠버네티스와 대화해 클러스터의 상태를 변경하는 방법을 설명한다.

9장, ‘디플로이먼트: 애플리케이션을 선언적으로 업데이트 하기’에서는 배포 개념을 소개하고 쿠버네티스 환경에서 애플리케이션을 실행하고 업데이트하는 올바른 방법을 설명한다.

10장, ‘스테이트풀셋: 복제된 스테이트풀 애플리케이션 배포하기’에서는 대개 안정적인 아이디와 상태가 필요한 스테이트풀 애플리케이션을 실행하는 전용 방법을 소개한다.



마지막으로 3부에서는 쿠버네티스 클러스터의 내부를 깊이 들여다보며 몇 가지 추가 개념을 소개하고, 앞서 배운 모든 내용을 넓은 관점에서 검토한다.

11장, ‘쿠버네티스 내부 이해하기’에서는 쿠버네티스를 구성하는 모든 컴포넌트와 각 컴포넌트의 역할을 설명한다. 또한 포드가 네트워크를 통해 통신하는 방법과 서비스가 여러 포드에서 로드밸런싱을 수행하는 방법도 설명한다.

12장, ‘쿠버네티스 API 서버 보안’에서는 인증 및 권한 부여를 통해 쿠버네티스 API 서버 및 확장 클러스터를 보호하는 방법을 설명한다.

13장, ‘클러스터 노드와 네트워크의 보안’에서는 포드가 노드의 리소스에 액세스할 수 있는 방법과 클러스터 관리자가 포드의 액세스를 방지하는 방법을 설명한다.

14장, ‘포드의 계산 리소스 관리’에서는 각 애플리케이션에서 계산 리소스의 사용을 제한하고 애플리케이션의 QoS(Quality of Service) 보장을 구성하며 개별 애플리케이션의 리소스 사용을 모니터링 한다. 또한 사용자가 너무 많은 리소스를 소비하지 못하게 하는 방법을 알려준다.

15장, ‘포드와 클러스터 노드의 오토스케일링’에서는 애플리케이션의 복제본을 자동으로 확장할 수 있게 쿠버네티스를 구성하는 방법과 현재 클러스터 노드 수가 추가 애플리케이션을 허용하지 않을 때 클러스터 크기를 늘리는 방법을 설명한다.

16장, ‘고급 스케줄링’에서는 포드가 특정 노드에만 스케줄되도록 하거나 포드가 다른 노드에 스케줄 되지 않도록 하는 방법을 보여준다. 그리고 포드가 함께 스케줄 됐는지 확인하는 방법이나 이러한 일이 발생하지 않도록 방지하는 방법을 보여준다.

17장, ‘애플리케이션 개발을 위한 Best Practice’에서는 애플리케이션을 개발해 클러스터의 구성원이 되는 방법을 설명한다. 또한 개발 중 마찰을 줄이기 위해 개발 및 테스트 워크플로우를 설정하는 방법에 대한 몇 가지 지침을 제공한다.

18장, ‘쿠버네티스 확장하기’에서는 사용자 지정 객체로 쿠버네티스를 확장하는 방법과 다른 사용자가 이를 수행하고 엔터프라이즈급 애플리케이션 플랫폼을 작성하는 방법을 보여준다.

이 장을 진행하면서 개별 쿠버네티스 컴포넌트에 대해 배울뿐만 아니라 kubectl 명령행 도구 사용에 대한 지식을 향상시킬 수 있다.





★ 지은이의 말 ★



레드햇(Red Hat)에서 몇 년 근무하다가 2014년 말, 신설된 클라우드 인에이블먼트(Cloud Enablement) 팀에 배정됐다. 새 팀의 임무는 쿠버네티스상에서 개발된 회사의 미들웨어 제품을 오픈시프트 컨테이너 플랫폼(OpneShift Container Platform)으로 가져오는 것이었다. 그 당시 쿠버네티스는 정식으로 발표되지 않은 초기 버전(v1.0)이었다.

소프트웨어의 적절한 방향을 설정하고 쿠버네티스가 제공하는 기능을 이용하려면 쿠버네티스의 모든 기능을 신속하게 파악해야 했다. 문제가 발생했을 때, 우리가 일을 잘못한 건지 아니면 쿠버네티스 초기 버전의 버그인지를 구분해내기가 어려웠다.

그 후로 쿠버네티스도 눈부시게 발전했고 나도 쿠버네티스를 많이 이해하게 됐다. 나는 쿠버네티스라는 말조차 생경할 때 쿠버네티스를 사용하기 시작했다. 지금은 클라우드와 온프레미스 데이터 센터(on-premises datacenters)에서 애플리케이션을 실행하는 데 가장 빠르게 성장하고 가장 많이 사용되는 방법으로, 소프트웨어 엔지니어라면 모르는 사람이 없을 정도다.

쿠버네티스를 접한 지 한 달쯤 뒤에 오픈시프트/쿠버네티스(OpenShift/Kubernetes)에서 JBoss 와일드플라이(JBoss WildFly) 애플리케이션 서버 클러스터를 실행하는 방법을 두 개의 글로 작성해 블로그에 게시했다. 그 당시 간단한 블로그 포스트를 보고 매닝 출판사의 담당자가 쿠버네티스에 대한 책을 써달라고 연락할 것이라고는 상상도 못했다. 내가 아니더라도 책을 쓸만한 누군가에게 연락했을 그 제안을 거절하지 않았다.

그렇게 나는 이 책을 쓰게 됐다. 1년 반 넘게 글쓰기와 연구에 매진한 끝에 마침표를 찍었다. 이 여정은 굉장히 값진 경험이었다. 그저 사용자로서 배울 때보다 책을 쓰면서 기술에 관해 훨씬 더 자세히 알 수 있었다. 이 과정에서 쿠버네티스에 대한 지식이 확장됐고, 쿠버네티스 자체도 진화했으므로 이전에 썼던 내용을 고치고 다듬어야 했다. 나는 완벽주의자다. 이 책에 만족하지는 않는다. 그럼에도 MEAP 프로그램(Manning Early Access Program)의 수많은 독자가 이 책을 쿠버네티스를 향한 훌륭한 안내서로 평가해주셔서 기쁘다.

내 목표는 독자가 기술 자체를 이해하고 도구를 사용해 쿠버네티스 클러스터에 애플리케이션을 효율적으로 개발하고 배포할 수 있도록 가르치는 데 있다. 이 책은 실제로 적정한 수준의 가용성을 갖는 쿠버네티스 클러스터를 실제로 설정하거나 유지하는 것에 중점을 두지 않았다. 대신에 마지막 파트를 통해 독자가 그러한 클러스터의 구성이 어떻게 되는지 확실히 이해할 수 있게 작성했다. 그리고 이런 주제를 이해하기 쉬운 추가적인 리소스를 포함하고 있다.

쿠버네티스라는 굉장한 시스템을 통해 최대한의 결과를 얻는 방법을 알아가며 이 책을 즐겁게 읽어 나가길 바란다.

1부 OVERVIEW



1장. 쿠버네티스 소개

__1.1 쿠버네티스 시스템의 필요성 이해

____1.1.1 모놀리식 애플리케이션에서 마이크로서비스로 전환하기

____1.1.2 애플리케이션에 일관된 환경 제공

____1.1.3 지속적 전달로 이동: 데브옵스와 노옵스

__1.2. 컨테이너 기술 소개

____1.2.1 컨테이너 이해하기

____1.2.2 도커 컨테이너 플랫폼 소개

____1.2.3 rkt 소개: 도커의 대안

__1.3 쿠버네티스 소개

____1.3.1 쿠버네티스 기원에 대한 이해

____1.3.2 넓은 시각으로 쿠버네티스 바라보기

____1.3.3 쿠버네티스 클러스터 아키텍처 이해하기

____1.3.4 쿠버네티스에서 애플리케이션 실행하기

____1.3.5 쿠버네티스의 이점 이해하기

__1.4 요약



2장. 도커와 쿠버네티스의 첫걸음

__2.1 컨테이너 이미지의 생성, 실행, 공유

____2.1.1 도커를 설치하고 Hello World 컨테이너 실행하기

____2.1.2 간단한 Node.js 앱 만들기

____2.1.3 이미지용 도커 파일(Dockerfile) 만들기

____2.1.4 컨테이너 이미지 만들기

____2.1.6 실행 중인 컨테이너 내부 탐색

____2.1.7 컨테이너 중지 및 제거

____2.1.8 이미지 레지스트리로 이미지 푸시하기

__2.2 쿠버네티스 클러스터 설정

____2.2.1 미니큐브를 사용한 로컬의 단일 노드 쿠버네티스 클러스터 실행

____2.2.2 구글 쿠버네티스 엔진(GKE)에서 호스팅된 쿠버네티스 클러스터의 사용

____2.2.3 alias와 kubectl 명령행 셋업하기

__2.3 쿠버네티스에서 첫 번째 앱 실행하기

____2.3.1 Node.js 앱 배포

____2.3.2 웹 애플리케이션 액세스하기

____2.3.3 시스템의 논리적 부분

____2.3.4 애플리케이션 수평 확장하기

____2.3.5 앱이 실행되고 있는 노드 검사하기

____2.3.6 쿠버네티스 대시보드 소개

__2.4 요약





2부 CORE CONCEPTS



3장. 포드: 쿠버네티스에서 컨테이너 실행하기

__3.1 포드 소개

____3.1.2 포드의 필요성 이해하기

____3.1.2 포드 이해하기

____3.1.3 컨테이너를 포드 전체에 적절하게 구성하기

__3.2 YAML 혹은 JSON 파일 디스크립터로 포드 만들기

____3.2.1 기존 포드의 YAML 디스크립터 검사하기

____3.2.2 포드를 위한 간단한 YAML 디스크립터 만들기

____3.2.3 kubectl을 사용해 포드 만들기

____3.2.4 애플리케이션 로그보기

____3.2.5 포드에 요청 보내기

__3.3 라벨로 포드 구성하기

____3.3.1 라벨 소개

____3.3.2 포드를 만들 때 라벨 지정하기

____3.3.3 기존 포드의 라벨 수정하기

__3.4 라벨 셀렉터를 통한 하위 집합 나열하기

____3.4.1 라벨 셀렉터를 사용해 포드 나열하기

____3.4.2 라벨 셀렉터에서 다중 조건 사용하기

__3.5 포드 스케줄링 제약을 위한 라벨과 셀렉터 사용하기

____3.5.1 워커노드 분류를 위해 라벨 사용하기

____3.5.2 노드 지정을 위한 포드 스케줄링 하기

____3.5.3 하나의 지정된 포드에 스케줄링하기

__3.6 포드에 주석 달기

____3.6.1 객체의 주석 찾아보기

____3.6.2 주석 추가 및 수정하기

__3.7 그룹 리소스의 네임스페이스 사용하기

____3.7.1 네임스페이스의 필요성 이해하기

____3.7.2 다른 네임스페이스와 네임스페이스의 포드 찾아보기

____3.7.3 네임스페이스 만들기

____3.7.4 다른 네임스페이스의 객체 관리하기

____3.7.5 네임스페이스가 제공하는 격리에 대해 이해하기

__3.8 포드를 중지하고 삭제하기

____3.8.1 이름으로 포드 삭제하기

____3.8.2 라벨 셀렉터로 포드 삭제하기

____3.8.3 전체 네임스페이스를 삭제해서 포드 삭제하기

____3.8.4 네임스페이스가 유지되는 동안 모든 포드 삭제하기

____3.8.5 네임스페이스의 (거의)모든 리소스 삭제하기

__3.9 요약



4장. 리플리케이션 및 기타 컨트롤러: 관리되는 포드 배포

__4.1 포드를 안정적으로 유지하기

____4.1.1 liveness probe 소개

____4.1.2 HTTP 기반의 liveness probe생성

____4.1.3 동작 중인 liveness probe 보기

____4.1.4 liveness probe의 추가 속성 구성하기

____4.1.5 효과적인 liveness probe 생성하기

__4.2 리플리케이션컨트롤러 소개

____4.2.1 리플리케이션컨트롤러의 동작

____4.2.2 리플리케이션컨트롤러 생성하기

____4.2.3 실행 중인 리플리케이션컨트롤러 보기

____4.2.4 리플리케이션컨트롤러의 범위 안팎으로 포드 이동

____4.2.5 포드 템플릿 변경

____4.2.6 수평 포드 스케일링

____4.2.7 리플리케이션컨트롤러 삭제하기

__4.3 리플리케이션컨트롤러 대신 리플리카셋 사용

____4.3.1 리플리카셋과 리플리케이션컨트롤러 비교

____4.3.2 리플리카셋 정의

____4.3.3 리플리카셋 생성 및 검사

____4.3.4 리플리카셋의 더욱 풍부한 라벨 셀렉터 사용하기

____4.3.5 리플리카셋 정리하기

__4.4 데몬셋으로 각 노드에 정확히 한 개의 포드 실행하기

____4.4.1 데몬셋을 사용해 모든 노드에서 포드 실행

____4.4.2 데몬셋을 사용해 특정 노드에서 포드를 실행

__4.5 완료 가능한 단일 태스크를 수행하는 포드 실행

____4.5.1 잡 리소스 소개

____4.5.2 잡리소스의 정의

____4.5.3 포드를 실행하는 잡 보기

____4.5.4 잡에서 다수의 포드 인스턴스 실행

____4.5.5 잡 포드를 완료하는 데 허용되는 시간 제한

__4.6 잡을 주기적으로 또는 한번만 실행하도록 스케줄링

____4.6.1 CronJob 만들기

____4.6.2 스케줄된 잡의 실행 방법 이해

__4.7 요약



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 NodePort 서비스 사용하기

____5.3.2 외부 로드 밸런서를 통해 서비스 노출하기

____5.3.3 외부 연결의 특성 이해하기

__5.4 Ingress 리소스를 통해 외부로 서비스 노출하기

____5.4.1 Ingress 리소스 생성하기

____5.4.2 Ingress를 통해 서비스 액세스하기

____5.4.3 동일한 Ingress를 통해 다수의 서비스 노출하기

____5.4.4 TLS 트래픽을 처리하기 위해 Ingress 설정하기

__5.5 포드가 연결을 수락할 준비가 되어 있을 때 신호 보내기

____5.5.1 준비 프로브 소개

____5.5.2 포드로 준비 프로브 추가하기

____5.5.3 실제환경에서 준비 프로브의 역할 이해하기

__5.6 각각의 포드를 찾기 위한 헤드리스 서비스 사용하기

____5.6.1 헤드리스 서비스 생성하기

____5.6.2 DNS를 통해 포드 발견하기

____5.6.3 모든 포드 발견하기(심지어 준비되지 않은 포드까지)

__5.7 서비스 문제 해결하기

__5.8 요약



6장. 볼륨: 컨테이너에 디스크 스토리지 연결

__6.1 볼륨 소개

____6.1.1 예제에서 볼륨 설명

____6.1.2 가능한 볼륨 유형 소개

__6.2 볼륨을 사용해 컨테이너 간에 데이터 공유하기

____6.2.1 emptyDir볼륨 사용하기

__6.3 워커노드 파일 시스템에 액세스하기

____6.3.1 hostPath 볼륨 소개

____6.3.2 hostPath 볼륨을 사용하는 시스템 포드 검사

__6.4 영구 스토리지 사용하기

____6.4.1 포드볼륨에서 GCE 영구 디스크 사용하기

____6.4.2 기본 영구 스토리지에서 다른 볼륨의 유형 사용하기

__6.5 기본 스토리지 기술에서 포드 분리하기

____6.5.1 PersistentVolumes(영구볼륨) 및PersistentVolumeClaims(영구볼륨클레임) 소개

____6.5.2 PersistentVolume 생성

____6.5.3 PersistentVolumeClaim을 생성해 PersistentVolume 할당하기

____6.5.4 포드에서 PersistentVolumeClaim 사용하기

____6.5.5 PersistentVolumes및 클레임 사용의 이점 이해하기

____6.5.6 PersistentVolumes재활용하기

__6.6 PersistentVolumes의 동적 프로비저닝

____6.6.1 스토리지 클래스리소스를 통해 사용 가능한 스토리지 유형 정의하기

____6.6.2 PersistentVolumeClaim의 스토리지 클래스 요청하기

____6.6.3 스토리지 클래스를 지정하지 않고 동적 프로비저닝하기

__6.7 요약



7장. ConfigMaps와 Secret: 애플리케이션 설정

__7.1 컨테이너화된 애플리케이션 설정

__7.2 컨테이너에 명령행 인자 전달

____7.2.1 도커에서 명령과 인자 정의하기

____7.2.2 쿠버네티스에서 명령과 인자를 재정의하기

__7.3 컨테이너를 위한 환경 변수 설정하기

____7.3.1 컨테이너 정의에 환경 변수 지정하기

____7.3.2 변수 값에서 다른 환경 변수 참조하기

____7.3.3 하드코딩된 환경 변수의 단점 이해하기

__7.4 ConfigMap을 통한 설정의 분리

____7.4.1 ConfigMaps 소개

____7.4.2 ConfigMap 생성하기

____7.4.3 컨테이너의 환경 변수로 ConfigMap 엔트리를 전달하기

____7.4.4 ConfigMap의 모든 항목을 한번에 환경 변수로 전달하기

____7.4.5 ConfigMap 항목을 명령행 인자로 전달하기

____7.4.6 ConfigMap 엔트리를 파일로 노출하기 위해 ConfigMap 볼륨 사용하기

____7.4.7 애플리케이션 다시 시작 없이 애플리케이션 설정 업데이트하기

__7.5 컨테이너에 민감한 데이터 전달을 위한 Secret 사용하기

____7.5.1 시크릿 소개

____7.5.2 기본 토큰 Secret 소개

____7.5.3 Secret 생성하기

____7.5.4 ConfigMaps와 Secret 비교하기

____7.5.5 포드에서 Secret 사용하기

____7.5.6 image pull Secrets 이해하기

__7.6 요약



8장. 애플리케이션에서 포드 메타데이터와 그 외의 리소스에 접근하기

__8.1 Downward API를 통한 메타데이터 전달하기

____8.1.1 사용 가능한 메타데이터 이해하기

____8.1.2 환경 변수를 통한 메타데이터 노출하기

____8.1.3 Downward API 볼륨 내의 파일을 통한 메타데이터 전달하기

__8.2 쿠버네티스 API 서버와 통신하기

____8.2.1 쿠버네티스 REST API 탐색하기

____8.2.2 포드 내에서 API 서버와 통신하기

____8.2.3 앰배서더 컨테이너와의 API 서버 통신 간소화

____8.2.4 클라이언트 라이브러리를 사용해 API 서버와 통신

__8.3 요약



9장. 디플로이먼트: 애플리케이션을 선언적으로 업데이트하기

__9.1 포드에서 실행 중인 애플리케이션 업데이트하기

____9.1.1 오래된 포드를 삭제하고 새로운 포드로 교체하기

____9.1.2 새로운 포드의 스핀 업 및 오래된 포드 삭제하기

__9.2 리플리케이션 컨트롤러를 통한 자동 롤링 업데이트 수행하기

____9.2.1 애플리케이션 초기 버전 실행

____9.2.2 kubectl을 통해 롤링 업데이트 수행하기

____9.2.3 kubectl 롤링 업데이트가 더 이상 사용되지 않는 이유 이해하기

__9.3 선언적으로 애플리케이션을 업데이트하기 위한 디플로이먼트 사용하기

____9.3.1 디플로이먼트 생성하기

____9.3.2 디플로이먼트 업데이트하기

____9.3.3 디플로이먼트 롤백하기

____9.3.4 롤아웃 속도 통제

____9.3.5 롤아웃 프로세스 일시 중지

____9.3.6 잘못된 버전의 롤아웃 방지

__9.4 요약



10장. 스테이트풀셋: 복제된 스테이트풀 애플리케이션 배포하기

__10.1 스테이트풀 포드 복제

____10.1.1 각각 분리된 저장소를 갖는 다수의 복제본 실행하기

____10.1.2 각 포드에 안정적인 ID 제공

__10.2 스테이트풀셋 이해하기

____10.2.1 스테이트풀셋과 레플리카셋 비교

____10.2.2 안정적인 네트워크 ID 제공

____10.2.3 각 스테이트풀 인스턴스에 안정적인 전용 스토리지 제공

____10.2.4 스테이트풀셋의 보장 이해하기

__10.3 스테이트풀셋 사용하기

____10.3.1 앱 및 컨테이너 이미지 만들기

____10.3.2 스테이트풀셋을 통한 애플리케이션 배포

____10.3.3 실제로 포드를 동작해보기

__10.4 스테이트풀셋에서 피어 발견

____10.4.1 DNS를 통한 피어 검색 구현

____10.4.2 스테이트풀셋 업데이트

____10.4.3
마르코 룩샤(Marko Lukša)

간단한 웹 애플리케이션부터 전체 ERP 시스템, 프레임 워크, 미들웨어 소프트웨어에 이르기까지 개발 경력만 20년이 넘는 전문 소프트웨어 엔지니어다. 6살 때 아버지가 구입한 중고 ZX 스펙트럼(ZX Xpectrum) 컴퓨터에서 처음 프로그래밍을 경험했다. 초등학교 시절 로고 프로그래밍 대회에서 전국 챔피언이 됐고, 여름 코딩 캠프에서는 파스칼로 프로그래밍 하는 법을 배웠다. 그 이후로 광범위한 프로그래밍 언어를 사용해 소프트웨어를 개발했다. 고등학교에 다니던 때는 웹이 겨우 시작되던 단계에서 동적 웹 사이트를 만들기 시작했다. 슬로베니아 류블랴나 대학(University of Ljubljana)에서 컴퓨터과학을 전공하면서 지역 회사의 의료와 통신 산업용 소프트웨어 개발로 분야를 옮겼다. 레드햇(Red Hat)에서 일하게 된 초기에 레드햇의 JBoss 미들웨어 제품을 이용해 오픈 소스로 구현된 구글 앱 엔진 API(Google App Engine API)를 개발했다. CDI/Weld, Infinispan/JBoss Data-Grid 등의 프로젝트에도 참여했다.

2014년 말부터 레드햇의 클라우드 지원 팀에서 쿠버네티스의 새로운 개발 상황에 관한 최신 정보를 제공하고 관련 기술을 사용해 회사의 미들웨어 소프트웨어가 쿠버네티스 및 오픈시프트(OpenShift)의 기능을 최대한 활용할 수 있도록 보장하는 역할을 하고 있다.





★ 옮긴이의 말 ★



네 명의 역자는 현재 IT전문회사 및 컨설팅회사에서 근무하며, 같은 회차 정보관리/컴퓨터시스템응용 기술사로 구성된 ‘108번역’이라는 소모임을 운영하고 있다. 최근 컨테이너 환경은 도커 엔진을 중심으로 쿠버네티스가 de-facto 표준이 되는 형국으로 변하고 있다. 마이크로서비스 환경으로 마이그레이션되는 최근 환경에서 수많은 도커를 유연하고 안정적으로 운영하기 위해서 고민하는 것은 당연하며 이에 오픈소스 프로젝트인 쿠버네티스가 그 답을 줄 것이다. 이 책은 애플리케이션 개발에 중점을 둔 개발자와 운영자 모두가 애플리케이션을 관리할 수 있는 관점에서 쓰여졌다. 무엇보다 쿠버네티스의 컴포넌트 각각에 대해 자세히 풀어 설명했으며 그림도 상세히 설명해 독자의 이해를 돕는다. 쿠버네티스에 대한 기본적인 이해부터 각각의 컴포넌트를 사용해 적용하는 법, 마지막으로 쿠버네티스 클러스터 내부까지 자세히 살펴보고 엔터프라이즈급 애플리케이션의 플랫폼까지 구축할 수 있도록 알려주고 있다. 이 책은 컨테이너 기반 오케스트레이션 플랫폼에 관심 있는 초급자뿐 아니라 실제 다양한 환경에 애플리케이션 배포를 원하는 중급 수준의 독자들에게 적합한 책이다. 이 책은 쿠버네티스 설치 및 운영에 필요한 다양한 정보를 제공하며 유연한 환경의 인프라를 구축할 수 있도록 가이드 해 줄 것이다.





★ 옮긴이 소개 ★



이형석

보안업계에서 가상화 연구에 매진하고 있다. 윈도우 가상화, 리눅스 가상화 연구 중 쿠버네티스를 만나게 되었고 가상화 기술과 컨테이너의 접목을 위해 노력하고 있다. 『쿠버네티스 마스터 2/e』(에이콘, 2018)의 역자다.

(현) 안랩 / 보안솔루션 개발

(현) IITP 평가위원

(현) NIPA 평가위원

(현) 과학기술정보통신부 한이음 멘토

(전) NCS 집필위원

컴퓨터시스템응용기술사 / CISA

비트컴퓨터 쿠버네티스 출강



김필수

(현) LG CNS TA(Technical Architecture)

(현) IITP 평가위원

(현) NIPA 평가위원

(현) 산업기술혁신 평가위원

(현) 디비가이드넷 전문위원

(전) NCS 집필위원

·아이리포 기술사 멘토로 알고리즘, 클라우드, 네트워크, 소프트웨어공학 등 다수의 출강

·정보관리기술사, CISA, PMP



정두현

개발자가 좋아서 Basic부터 독학하며 웹, RIA, FB 웹앱, 모바일 등 다양한 개발을 해왔다. 플랫폼화를 추구하며 개발 팀장으로 생산성과 개발자의 환경 조성을 고민하는 리더다. 조금 일찍 개발 팀장 직함을 받아 많은 시행착오를 거치며 애자일을 도입하고 스크럼마스터를 역임했다. 현재는 통합 아키텍트 팀에서 소프트웨어 아키텍트로 표준화와 프로젝트를 돕고 있다.

(현) (주)씨에스리컨설팅 / 소프트웨어 아키텍트

(현) IITP, NIPA, 중기원 평가위원

(전) 계원대 임베디드과 출강

(전) 모션블루 개발 팀장

(전) 웹머니 코리아(Webmoney Korea) 시스템 팀장



최정현

보안업계에서 엔드포인트 보안을 위한 커널 엔진을 다수 개발했고 현재는 디바이스 드라이버 전문 기업에서 다양한 디바이스 및 시스템을 위한 장치 드라이버 및 시스템 소프트웨어에 관한 개발, 컨설팅을 수행하고 있다.

(현) 데브구루

(현) SW마에스트로 과정 멘토

(현) 미래창조과학부 한이음 ICT 멘토

(전) 잉카인터넷

등록된 서평이 없습니다.
『Windows Debugging 2/e: WinDbg로 배우는 윈도우 디버깅』...
최바울, 이태화, 김희준, 김성현
선택된 상품을 찜하실 수 있습니다. 선택된 상품을 바로구매 하실 수 있습니다.
컴퓨터 비전(Computer Vision)...
오일석
선택된 상품을 찜하실 수 있습니다. 선택된 상품을 바로구매 하실 수 있습니다.
Solidworks Basic(솔리드웍스 베이직)(2017)...
원동현
선택된 상품을 찜하실 수 있습니다. 선택된 상품을 바로구매 하실 수 있습니다.
 
전체평균(0)
회원평점   회원서평수 0
에이콘 출판사의 신간
『파이썬으로 풀어보는 회귀분석: 단순선형회귀분석부터 고급 회귀분석까지』
루카 마싸론, 알베르토 보스체티 저
0원
(0%↓+1%)
 
『파이썬으로 풀어보는 회귀분석: 단순선형회귀분석부터 고급 회귀분석까지』
루카 마싸론, 알베르토 보스체티 저
27,000원
(10%↓+5%)
 
『빅데이터 분석을 위한 스칼라와 스파크: 대용량 빅데이터 분석과 머신 러닝까지 활용하는』
레자울 카림, 스리다 알라 저
45,000원
(10%↓+5%)
 
『인텔리제이 IDEA: 기본 사용법부터 고급 기능까지 마스터하기』
야마모토 유스케, 이마이 마사노부 저
25,200원
(10%↓+5%)
 
『모바일 UX 디자인 : 기획부터 프로토타이핑까지 디자이너의 능력을 확장시키는 방법』
파블로 페레아, 파우 히네르 저
31,500원
(10%↓+5%)
 
이메일주소수집거부