Top

gRPC 시작에서 운영까지 [도커와 쿠버네티스를 위한 클라우드 네이티브 애플리케이션 구축]

  • 원서명gRPC: Up and Running: Building Cloud Native Applications with Go and Java for Docker and Kubernetes (ISBN 9781492058335)
  • 지은이카순 인드라시리(Kasun Indrasiri), 다네쉬 쿠루푸(Danesh Kuruppu)
  • 옮긴이한성곤
  • ISBN : 9791161754635
  • 25,000원
  • 2020년 11월 12일 펴냄
  • 페이퍼백 | 284쪽 | 188*235mm
  • 시리즈 : 클라우드 컴퓨팅

책 소개

소스 코드 파일은 여기에서 내려 받으실 수 있습니다.
https://github.com/switchover/grpc-up-and-running

요약

클라우드 및 마이크로서비스 아키텍처의 출현으로 오늘날 애플리케이션은 프로세스간 통신 기술을 사용해 연결되며, gRPC는 가장 널리 사용되는 효율적인 통신 기술 중 하나이다. 이 책은 gRPC를 처음 시작하는 아키텍트에게 애플리케이션 간 통신 설계를 위한 깊이 있는 이해를 제공한다. 또한 개발자들이 gRPC를 실제 서비스에 적용할 때 필요한 인증과 권한 관리, 확장을 위한 로드 밸런싱 등 다양한 고급 기술도 실제 사례를 중심으로 Go와 Java 언어를 통해 제시한다.

이 책에서 다루는 내용

■ gRPC의 기본 사항을 이해하고 유사한 기술과 비교하기
■ 실제 사례를 통한 gRPC 통신 패턴 확인
■ gRPC 통신 프로토콜의 내부 세부 사항
■ 인터셉터, 멀티플렉싱, 에러 처리 등의 고급 gRPC 기능 탐색
■ 통신 채널을 보호하고 사용자를 인증하기
■ gRPC 애플리케이션 수명 주기에 따라 테스트, CI/CD 통합, 도커, 쿠버네티스 배포

이 책의 대상 독자

여러 프로세스 간 통신 기술을 사용해 분산 애플리케이션과 마이크로서비스를 구축하는 개발자를 위한 책이다. 개발자가 분산된 애플리케이션이나 마이크로서비스를 개발하려면 gRPC의 기본 사항과 함께 서비스 간 통신이 필요한 때와 사용하는 방법, 실제 환경에서의 모범 사례 등을 배워야 한다. 아울러 마이크로서비스나 클라우드 네이티브 아키텍처를 채택하고 서비스 통신 방식을 설계하는 아키텍트는 다른 기술과 비교해보고, 언제 사용해야 하는지, 또는 언제 사용하지 말아야 하는지 등의 지침을 제공해야 하기 때문에 많은 인사이트를 얻을 수 있다.
이 책을 읽는 개발자와 아키텍트는 프로세스 간 통신 기술, 서비스 지향 아키텍처(SOA, Service-Oriented Architecture), 마이크로서비스와 같은 기본적인 분산 컴퓨팅의 기본 지식이 있다고 가정한다.

이 책의 구성

실제 적용 사례를 통해 이론적인 개념을 설명하며, Go 언어와 자바를 사용한 코드 예제를 광범위하게 활용해 각 개념에 대한 실무 경험을 제공한다. 이 책은 다음과 같이 8개의 장으로 구성됐다.
1장, ‘gRPC 소개’에서는 gRPC 기본 사항의 기초 지식을 제공하고 REST, GraphQL, 다른 RPC 기술과 같은 유사한 프로세스 간 통신 기술 스타일을 비교한다.
2장, ‘gRPC 시작’에서는 Go 언어와 자바를 사용해 완전한 gRPC 애플리케이션 구축의 첫 번째 경험을 제공한다.
3장, ‘gRPC 통신 패턴’에서는 실제 예제를 통해 gRPC 통신 패턴을 살펴본다.
4장, ‘gRPC: 동작 원리’에서는 gRPC 내부에 관심이 있는 고급 사용자를 위한 장으로, 서버와 클라이언트 간 gRPC 통신의 모든 단계와 네트워크상 동작 방식을 설명한다. 5장, ‘gRPC: 고급 기능’에서는 인터셉터(interceptors), 데드라인(deadlines), 메타데이터(metadata) 멀티플렉싱(multiplexing), 로드밸런싱(load balancing) 등과 같은 주요 고급 기능을 설명한다.
6장, ‘보안 적용 gRPC’에서는 통신 채널을 보호하는 방법과 gRPC 애플리케이션에 대한 사용자 인증과 접근 제어에 대한 포괄적인 이해를 제공한다.
7장, ‘서비스 수준 gRPC 실행’에서는 gRPC 애플리케이션의 전체 개발 주기(development life cycle)를 살펴본다. gRPC 애플리케이션의 테스팅, CI/CD와의 통합, 도커(Docker), 쿠버네티스 배포와 실행, 상태 확인을 알아본다.
8장, ‘gRPC 생태계’에서는 gRPC의 유용한 지원 요소들을 설명한다. 대부분의 프로젝트는 gRPC 기반의 실제 애플리케이션을 구축할 때 유용하다.

저자/역자 소개

지은이의 말

현대 소프트웨어 애플리케이션은 프로세스 간 통신 기술을 활용해 컴퓨터 네트워크를 통해 서로 연결되는 경우가 많다. gRPC는 이런 분산 애플리케이션이나 마이크로서비스 구축을 위해 사용되는 고성능 RPC(Remote Procedure Calls)를 기반으로 하는 최신 프로세스 간 통신 스타일이며, 마이크로서비스와 클라우드 네이티브 애플리케이션의 출현으로 gRPC 채택이 기하급수적으로 증가하고 있다.

이 책을 쓰게 된 것은 gRPC 활용이 증가하면서 gRPC 애플리케이션 개발 주기의 모든 단계에서 최고의 참조 가이드로 사용할 수 있는 깊이 있는 책이 필요하다고 느꼈기 때문이다. gRPC의 다양한 리소스와 코드 샘플이 도처(문서, 블로그, 기사, 콘퍼런스 토크 등)에 있지만 gRPC 애플리케이션을 개발하는 데 사용할 수 있는 단일 리소스는 없을뿐더러 내부 프로토콜과 동작 방식의 리소스도 없다.
이런 도전을 극복하고 gRPC의 기본 사항, 기존 프로세스 간 통신 기술과의 차이점, 실제 gRPC 통신 패턴, Go 언어와 자바를 사용한 애플리케이션 개발, 이면의 동작 방식, 실제 환경에서의 실행, 쿠버네티스 및 기타 생태계와의 동작 방식에 대해 포괄적인 이해를 제공하고자 한다.

지은이 소개

카순 인드라시리(Kasun Indrasiri)

마이크로서비스, 클라우드 네이티브와 엔터프라이즈 통합 아키텍처에서 광범위한 경험을 가진 저자이자 아키텍트다. WSO21의 통합 아키텍처 책임자이자 WSO2 엔터프라이즈 인터그레이터(Enterprise Integrator)의 제품 관리자이기도 하다. 『엔터프라이즈 환경을 위한 마이크로서비스』(2020, 에이콘)를 저술했으며 산호세의 오라일리 소프트웨어 아키텍처 콘퍼런스(O'Reilly Software Architecture Conference) 2019, 시카고의 GOTO Con 2019와 WSO2 콘퍼런스 등에서 강연을 했다. 현재 캘리포니아 산호세에 거주하며 샌프란시스코 베이지역에서 가장 큰 마이크로서비스 모임 중 하나인 ‘실리콘밸리 마이크로서비스, API와 통합(Silicon Valley Microservices, APIs and Integration)’ 밋업(meetup)의 창립자다.

다네쉬 쿠루푸(Danesh Kuruppu)

엔터프라이즈 통합과 마이크로서비스 기술 분야에서 5년 이상의 경험을 쌓은 WSO2의 기술 책임자다. 오픈소스이자 클라우드 네이티브 프로그래밍 언어인 발레리나(Ballerina)에 gRPC 지원을 추가하는 주요 설계자이자 개발자다. gRPC 커뮤니티의 일원으로 자바용 WSO2 마이크로서비스 프레임워크와 WSO2 거버넌스 레지스트리의 주요 공헌자이기도 하다.

옮긴이의 말

클라우드 네이티브와 마이크로서비스 아키텍처의 출현과 함께 도커와 같은 컨테이너 기반 시스템 구축과 운영은 급변하는 비즈니스와 기술 변화에 빠르게 적응하기 위한 기업에게는 필수를 넘어 기본이 됐다. 아울러 클라우드와 마이크로서비스를 적극 활용하기 위한 폴리글랏 프로그래밍(polyglot programming)과 다양한 서비스 간 통신 기술은 핵심 기술로 부각되고 있다. 특히 다양한 언어와 시스템과의 효율적인 통신을 위한 gRPC는 중요한 기술로 빠르게 자리 잡았다.
gRPC는 구글 데이터센터에서 수천 개의 여러 서비스를 연결하고자 만들어져 10년 이상 활용된 스터비(Stubby)라는 소프트웨어에서 시작됐고, 2015년 오픈소스로 공개된 이후 넷플릭스와 같은 대형 서비스에 적극적으로 활용되고 있으며, 여러 오픈소스 커뮤니티의 적극적인 지원으로 계속 발전하고 있다. 특히 현재 공식적으로 지원되는 언어는 여러 시스템 환경과 컴파일러를 포함하여 C/C++, C#, 자바, 파이썬, 루비 등의 전통적인 언어뿐만 아니라 오브젝티브C, Go, Node.js, 다트(Dart), 코틀린(Kotlin) 등 비교적 최신 언어도 포함한다.
이 책은 gRPC 기본적인 활용의 실제 사례를 기반으로 다양한 가이드를 제공할 뿐만 아니라 기존 통신 기술과의 비교를 통해 애플리케이션 간 통신을 설계하는 소프트웨어 아키텍트에게 훌륭한 지침을 제공한다. 또한 여러 통신 패턴과 내부 동작 방식을 깊이 있게 설명해 통신 기술을 포괄적으로 이해할 수 있도록 돕고, 서비스 수준의 실제 적용 시에 고려돼야 할 다양한 기술 요소를 자세하게 설명한다. 인증과 접근 통제, 서비스 확장을 위한 로드밸런싱 등의 고급 기술을 포함하며, 개발 주기에 필요한 테스팅, CI/CD 통합과 다양한 모니터링 기술도 잘 제시하고 있다.
이 책이 gRPC 통신 기술을 활용한 견고한 애플리케이션과 마이크로서비스 개발에 토대가 되기를 희망한다.

옮긴이 소개

한성곤

현재 삼성SDS에서 코드 품질과 관련된 다양한 업무를 수행하고 있다. 관련 지표 수립과 이를 측정하기 위한 툴 개발뿐만 아니라 개선을 위한 다양한 활동(리팩토리/클린코드 교육, 코드 리뷰 및 점검 수행 등)도 하고 있다. 최근에는 Go 언어 등을 활용한 마이크로서비스 기반의 코드봇 시스템 개발을 리딩하고 있으며, 변경된 코드에 대해 여러 점검을 자동으로 수행하고 결과를 제공한다.
20여 년 가까이 개발과 소프트웨어 아키텍트로서 나름 열심히 살았지만 뭔가 생산적인 활동을 하지 못했던 점을 아쉬워하며, 늦은 나이임에도 불구하고 최근 다양한 활동을 하려고 노력 중이다. 특허 출원, 콘퍼런스 발표, 오픈소스 소프트웨어 활동 등을 하고 있으며, 첫 번역인 이 책도 그 노력 중 하나다. 저서도 집필 중인데, 올해 안에 마무리하고자 노력하고 있다.

목차

목차
  • 1장. gRPC 소개
    • gRPC
      • 서비스 정의
      • gRPC 서버
      • gRPC 클라이언트
      • 클라이언트-서버 메시지 흐름
    • 프로세스 간 통신의 역사
      • 기존 RPC
      • SOAP
      • REST
      • gRPC의 시작
      • 왜 gRPC인가?
      • 다른 프로토콜과의 비교: 그래프QL과 쓰리프트
    • gRPC 실사례
      • 넷플릭스
      • etcd
      • 드롭박스
    • 요약

  • 2장. gRPC 시작
    • 서비스 정의 작성
      • 메시지 정의
      • 서비스 정의
    • 구현
      • 서비스 개발
      • gRPC 클라이언트 개발
    • 빌드와 실행
      • Go 서버 빌드
      • Go 클라이언트 빌드
      • Go 서버와 클라이언트 실행
      • 자바 서버 빌드
      • 자바 클라이언트 빌드
      • 자바 서버와 클라이언트 실행
    • 요약

  • 3장. gRPC 통신 패턴
    • 단순 RPC(단일 RPC)
    • 서버 스트리밍 RPC
    • 클라이언트 스트리밍 RPC
    • 양방향 스트리밍 RPC
    • 마이크로서비스 통신을 위한 gRPC
    • 요약

  • 4장. gRPC: 동작 원리
    • RPC 흐름
    • 프로토콜 버퍼를 사용한 메시지 인코딩
      • 인코딩 기술
    • 길이-접두사 지정 메시지 프레이밍
    • HTTP/2를 통한 gRPC
      • 요청 메시지
      • 응답 메시지
      • gRPC 통신 패턴에서의 메시지 흐름 이해
    • gRPC 구현 아키텍처
    • 요약

  • 5장. gRPC: 고급 기능
    • 인터셉터
      • 서버 측 인터셉터
      • 클라이언트 측 인터셉터
    • 데드라인
    • 취소 처리
    • 에러 처리
    • 멀티플렉싱
    • 메타데이터
      • 메타데이터 생성과 조회
      • 메타데이터 전송과 수신: 클라이언트 측
      • 메타데이터 전송과 수신: 서버 측
      • 네임 리졸버
    • 로드밸런싱
      • 로드밸런서 프록시
      • 클라이언트 측 로드밸런싱
      • 압축
    • 요약

  • 6장. 보안 적용 gRPC
    • TLS를 사용한 gRPC 채널 인증
      • 단방향 보안 연결 활성화
      • mTLS 보안 연결 활성화
    • gRPC 호출 인증
      • 베이직 인증 사용
      • OAuth 2.0 사용
      • JWT 사용
      • 구글 토큰 기반 인증 사용
    • 요약

  • 7장. 서비스 수준 gRPC 실행
    • gRPC 애플리케이션 테스트
      • gRPC 서버 테스트
      • gRPC 클라이언트 테스트
      • 부하 테스트
      • 지속 통합
    • 배포
      • 도커로의 배포
      • 쿠버네티스로의 배포
    • 관찰 가능성
      • 메트릭
      • 로그
      • 추적
      • 디버깅과 문제 해결
      • 추가 로깅 활성화
    • 요약

  • 8장. gRPC 생태계
    • gRPC 게이트웨이
    • gRPC를 위한 HTTP/JSON 트랜스코딩
    • gRPC 서버 리플렉션 프로토콜
    • gRPC 미들웨어
    • 상태 확인 프로토콜
    • gRPC 상태 프로브
    • 다른 생태계 프로젝트
    • 요약

도서 오류 신고

도서 오류 신고

에이콘출판사에 관심을 가져 주셔서 고맙습니다. 도서의 오탈자 정보를 알려주시면 다음 개정판 인쇄 시 반영하겠습니다.

오탈자 정보는 다음과 같이 입력해 주시면 됩니다.

(예시) p.100 아래에서 3행 : '몇일'동안 -> 며칠동안

정오표

정오표

코드 수정 사항은 여기에서 살펴보실 수 있습니다.

https://github.com/switchover/grpc-up-and-running

[p.38 : 2행]
폴리글랏(ployglot)
->
폴리글랏(polyglot)

[p.45 : 4행]
기존 클라이언트-서버 통신에 근본적으로 다른 접근 방법의 고정된 계약 방식을 사용한다.
->
기존의 클라이언트-서버 통신에 근본적으로 다른 접근 방식을 제공한다. 반면 gRPC는 클라이언트와 서버간 원격 메서드에 고정된 계약 방식을 사용한다.

[p.54 : 두 번째 코드 2-4]
코드 2-4
->
코드 2-5

[p.66 : 옮긴이 메모]
코드 2-4
->
코드 2-5

[p.217 : 16행 ghz 명령 실행]
(-d 옵션 뒤쪽 공백 추가 및 0.0.0.0:50051 -> localhost:50051변경)


->

[p.220 : 20행 docker 빌드 명령]
(뒤쪽 “.” 추가)
docker image build -t grpc-productinfo-server -f server/Dockerfile
->
docker image build -t grpc-productinfo-server -f server/Dockerfile .

[p.257 : 맨 하단 curl 호출 부분]
(마지막 라인은 명령이 아닌 출력 내용으로 뒤쪽 \ 부분 삭제)
$ curl -X POST http://localhost:8081/v1/product \
-d '{"name": "Apple", "description": "iphone7", "price": 699}' \
"38e13578-d91e-11e9"
->
$ curl -X POST http://localhost:8081/v1/product \
-d '{"name": "Apple", "description": "iphone7", "price": 699}'

(* 마지막 "38e13578-d91e-11e9" 라인은 출력된 결과로 생성된 제품 ID입니다.)