장바구니 담기 close

장바구니에 상품을 담았습니다.

gRPC 시작에서 운영까지

gRPC 시작에서 운영까지

  • 카순인드라시리 ,다네쉬쿠루푸
  • |
  • 에이콘출판
  • |
  • 2020-11-12 출간
  • |
  • 284페이지
  • |
  • 188 X 235 X 16 mm
  • |
  • ISBN 9791161754635
판매가

25,000원

즉시할인가

22,500

배송비

무료배송

(제주/도서산간 배송 추가비용:3,000원)

수량
+ -
총주문금액
22,500

※ 스프링제본 상품은 반품/교환/환불이 불가능하므로 신중하게 선택하여 주시기 바랍니다.

출판사서평




★ 이 책에서 다루는 내용 ★

■ 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 기반의 실제 애플리케이션을 구축할 때 유용하다.

★ 옮긴이의 말 ★

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


목차


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 상태 프로브
__다른 생태계 프로젝트
__요약

교환 및 환불안내

도서교환 및 환불
  • ㆍ배송기간은 평일 기준 1~3일 정도 소요됩니다.(스프링 분철은 1일 정도 시간이 더 소요됩니다.)
  • ㆍ상품불량 및 오배송등의 이유로 반품하실 경우, 반품배송비는 무료입니다.
  • ㆍ고객님의 변심에 의한 반품,환불,교환시 택배비는 본인 부담입니다.
  • ㆍ상담원과의 상담없이 교환 및 반품으로 반송된 물품은 책임지지 않습니다.
  • ㆍ이미 발송된 상품의 취소 및 반품, 교환요청시 배송비가 발생할 수 있습니다.
  • ㆍ반품신청시 반송된 상품의 수령후 환불처리됩니다.(카드사 사정에 따라 카드취소는 시일이 3~5일이 소요될 수 있습니다.)
  • ㆍ주문하신 상품의 반품,교환은 상품수령일로 부터 7일이내에 신청하실 수 있습니다.
  • ㆍ상품이 훼손된 경우 반품 및 교환,환불이 불가능합니다.
  • ㆍ반품/교환시 고객님 귀책사유로 인해 수거가 지연될 경우에는 반품이 제한될 수 있습니다.
  • ㆍ스프링제본 상품은 교환 및 환불이 불가능 합니다.
  • ㆍ군부대(사서함) 및 해외배송은 불가능합니다.
  • ㆍ오후 3시 이후 상담원과 통화되지 않은 취소건에 대해서는 고객 반품비용이 발생할 수 있습니다.
반품안내
  • 마이페이지 > 나의상담 > 1 : 1 문의하기 게시판 또는 고객센터 1800-7327
교환/반품주소
  • 경기도 파주시 문발로 211 1층 / (주)북채널 / 전화 : 1800-7327
  • 택배안내 : CJ대한통운(1588-1255)
  • 고객님 변심으로 인한 교환 또는 반품시 왕복 배송비 5,000원을 부담하셔야 하며, 제품 불량 또는 오 배송시에는 전액을 당사에서부담 합니다.