본문 바로가기

도서 소개

Go 언어를 활용한 분산 서비스 개발

분산 서비스 밑바닥부터 구축하고 나의 Go 능력은 하늘을 뚫고

 

 

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

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


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

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

 

출판사 제이펍
저작권사 Pragmatic Bookshelf
원서명 Distributed Services with Go (9781680507607)
도서명 Go 언어를 활용한 분산 서비스 개발
부제 Go 언어로 만들고 쿠버네티스로 배포하는 나만의 분산 서비스
지은이 트래비스 제프리
옮긴이 정현석
감수자 (없음)
시리즈 (없음)
출판일 2022. 11. 08
페이지 268쪽
판 형 46배판변형(188*245*13.6)
제 본 무선(soft cover)
정 가 27,000원
ISBN 979-11-92469-51-5 (93000)
키워드 고랭, 클라이언트, 서버, 네트워크, 배포, 테스트, gRPC, CA, TLS, 래프트
분 야 프로그래밍 언어 / Go / 네트워크

 


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

 

관련 포스트

2022.10.24 - [출간 전 책 소식] - Go 스킬 레벨업 고랭 Go Go 고로 짜

 

관련 시리즈

■ (없음)

 

관련 도서

Go 언어를 활용한 네트워크 프로그래밍

실무에 바로 쓰는 Go 언어 핸즈온 가이드

 

관련 파일 다운로드

■ (없음)

 




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

 

미리보기(차례, 옮긴이 머리말, 베타리더 후기, 추천사, 감사의 글, 이 책에 대하여, 1장)

 

정오표 페이지
■ (등록되는 대로 링크를 걸겠습니다.)

 

 

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

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


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

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

 

도서 소개

더 이상 Stop은 없다 Go 스킬 레벨업 Go Go
Go 언어로 만들고 쿠버네티스로 배포하는 나만의 분산 서비스

 

Go의 강력한 동시성 기능 덕분에 도커, 쿠버네티스, 이스티오, Ectd, 프로메테우스 등의 클라우드 네이티브 도구가 개발될 수 있었다. 엔지니어링 스킬을 향상하고자 하는 고퍼들을 위해, 이 책에서는 Go가 가장 빛나는 분야인 분산 서비스를 처음부터 끝까지 만들어볼 수 있다.

 

1부는 프로젝트의 준비 단계로, 1장에서는 JSON 서버를 만들며 앞으로 만들 프로젝트의 감을 잡고, 2장은 프로토콜 버퍼(protobuf)를 살펴본다. 3장은 프로젝트에서 계속 사용할 커밋 로그 패키지를 만들어본다. 2부에서 본격적인 네트워크 서비스 구축에 들어간다. 4장은 gRPC 서비스 및 서버 구현을 다룬다. 5장은 서비스의 보안(TLS)을, 6장은 관측 가능성 측면(로그, 메트릭, 트레이스)을 살펴보고 구현한다.

 

3부는 여기까지 만든 서비스를 분산화하여 가용성, 복원성, 확장성을 높인다. 7장은 서프를 이용한 서버 측 서비스 디스커버리, 8장은 래프트를 이용한 합의를 통한 서비스 간 조율, 9장은 클라이언트 측 서버 디스커버리 및 로드 밸런싱을 다룬다. 4부는 대망의 배포다. 10장은 쿠버네티스와 헬름을 이용한 로컬 배포, 11장은 GKE로 인터넷에 배포하는 방법을 살펴본다.

 

스토리지 처리의 기본 요소에서 시작해 클라이언트 및 서버 네트워킹을 숙련하고, 서버 인스턴스 배포, 구축, 테스트까지 분산 서비스의 모든 과정을 익힐 수 있다. 웹에서 돌아가는 분산 서비스 하나를 만들고 배포한다는 것, Go 개발 스킬을 향상하는 데 이보다 나은 선택은 없다.

 

주요 내용

  • 자신만의 분산 서비스를 만들고 오픈소스 프로젝트에 기여
  • gRPC를 사용하여 네트워크화된 보안 클라이언트 및 서버 구축
  • 메트릭, 로그, 트레이스로 계측되는 관측 가능한 서비스를 통해 시스템 디버깅
  • 자체 인증 기관(CA)을 만들어 TLS로 내부 웹 서비스 인증
  • 서비스 디스커버리로 클러스터상 노드 추가/제거 자동 처리
  • 래프트(Raft) 합의 알고리즘에 의한 상태 머신으로 분산 시스템 조정
  • 애플리케이션과 라이브러리를 모듈식으로 구성하기
  • 응용프로그램을 구성하고 실행할 CLI 작성
  • 분산 시스템을 로컬에서 실행하고 쿠버네티스를 사용해 클라우드에 배포
  • 애플리케이션을 테스트하고 벤치마킹하기

 

지은이 소개

트래비스 제프리(Travis Jeffery)

2001년부터 소프트웨어를 개발하고 있다. 모카(Mocha), 타임콥(Timecop) 등의 오픈소스 프로젝트에 참여했고, 세그먼트(Segment), 콘플루언트(Confluent) 등의 스타트업을 창립했다

 

 

옮긴이 소개

정현석

LG전자에서 소프트웨어 엔지니어로 사회에 첫발을 내디뎠다. 10년을 조금 채우지 못하고 나와 개발에 대한 다양한 고민과 방황, 그리고 성장을 겪었다. 공부 모임과 독서, 개발을 비롯한 다양한 분야를 넘나드는 배움을 꾸준히 이어가며, 다만 어제의 나보다 나아지려 노력하는 하루를 살아가고 있다. Go 언어를 무척 아낀다.

 

 

차례

옮긴이 머리말 ix

베타리더 후기 xi

추천사 xiii

감사의 글 xv

이 책에 대하여 xvii

 

PART I 시작

 

CHAPTER 1 프로젝트 시작 3

1.1 분산 시스템에 HTTP의 JSON 서비스 적용하기 4

1.2 프로젝트 환경 설정하기 5

1.3 커밋 로그 프로토타입 만들기 6

1.4 HTTP의 JSON 만들기 7

1.5 서버 실행하기 10

1.6 API 테스트하기 11

1.7 마치며 12

 

CHAPTER 2 프로토콜 버퍼와 구조체 13

2.1 프로토콜 버퍼를 쓰는 이유 15

더보기

__2.1.1 일관된 스키마 15

__2.1.2 버전 관리 제거 15

__2.1.3 줄어드는 보일러플레이트 코드 16

__2.1.4 확장성 16

__2.1.5 언어 불가지론 16

__2.1.6 성능 16

2.2 프로토콜 버퍼 컴파일러 설치하기 16

2.3 프로토콜 버퍼로 도메인 자료형 정의하기 18

2.4 프로토콜 버퍼 컴파일하기 19

2.5 생성한 코드를 이용하여 작업하기 21

2.6 마치며 22

 

CHAPTER 3 로그 패키지 작성 23

3.1 로그는 강력한 도구 23

3.2 로그의 작동 원리 25

3.3 로그 만들기 26

__3.3.1 스토어 만들기 26

__3.3.2 인덱스 만들기 32

__3.3.3 세그먼트 만들기 38

__3.3.4 로그 코딩하기 44

3.4 마치며 54

 

PART 2 네트워크

 

CHAPTER 4 gRPC 요청 처리 57

4.1 gRPC에 관하여 58

4.2 서비스를 만들 때의 목표 58

4.3 gRPC 서비스 정의하기 60

4.4 gRPC 플러그인으로 컴파일하기 62

4.5 gRPC 서버 구현하기 62

__4.5.1 gRPC의 에러 처리 65

__4.5.2 인터페이스를 이용한 의존관계 역전 70

4.6 서버 등록하기 71

4.7 gRPC 서버와 클라이언트 테스트하기 71

4.8 마치며 76

 

CHAPTER 5 서비스 보안 78

5.1 서비스 보안의 세 단계 79

__5.1.1 주고받는 데이터의 암호화 79

__5.1.2 클라이언트 인증 80

__5.1.3 클라이언트 권한 81

5.2 TLS로 서버 인증하기 81

__5.2.1 CFSSL로 나만의 CA 작동하기 81

5.3 TLS 상호 인증으로 클라이언트 인증하기 90

5.4 ACL로 권한 부여하기 92

5.5 마치며 104

 

CHAPTER 6 시스템 관측 105

6.1 세 종류의 원격 측정 데이터 105

__6.1.1 메트릭 106

__6.1.2 구조화 로그 107

__6.1.3 트레이스 108

6.2 서비스를 관측 가능하게 만들기 109

6.3 마치며 116

 

PART 3 분산

 

CHAPTER 7 서버 간 서비스 디스커버리 119

7.1 서비스 디스커버리를 사용하는 이유 119

7.2 서비스 디스커버리 넣어주기 120

7.3 서프를 이용한 서비스 디스커버리 122

7.4 디스커버드 서비스의 요청과 로그 복제 130

7.5 디스커버리와 종단 간 서비스의 테스트 142

7.6 마치며 146

 

CHAPTER 8 합의를 통한 서비스 간 조율 148

8.1 래프트 알아보기 148

__8.1.1 리더 선출 149

__8.1.2 로그 복제 150

8.2 서비스에 래프트 구현하기 151

__8.2.1 래프트 설정 153

__8.2.2 로그 API 157

__8.2.3 유한상태 머신 159

__8.2.4 스트림 계층 165

__8.2.5 디스커버리 통합 167

__8.2.6 분산 로그 테스트 170

8.3 하나의 포트에서 여러 서비스를 실행하는 다중화 173

8.4 마치며 180

 

CHAPTER 9 클라이언트 측 서버 디스커버리와 로드 밸런싱 181

9.1 세 가지 로드 밸런싱 전략 181

9.2 gRPC 클라이언트 측 로드 밸런싱 182

9.3 서버를 찾을 수 있게 만들기 184

9.4 서버 정보 가져오기 188

9.5 피커로 요청 경로를 정하고 밸런스 잡기 195

9.6 디스커버리와 밸런싱 종단 간 테스트 200

9.7 마치며 202

 

 

 

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

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