본문 바로가기

도서 소개

심각한 테라폼 중독입니다

 

구성하고, 관리하고, 확장하는 테라폼의 정석

 

빠르게 변화하는 클라우드 환경에서 인프라를 안정적으로 운영하려면 선언만으로는 부족하다. 이 책은 테라폼을 실무에 제대로 적용하기 위한 실전 가이드다. 상태 관리, 실행 환경 분리, 커스텀 모듈 설계, 다양한 프로바이더 연용 등 핵심 개념을 하나씩 짚어간다. 또한, YAML과 CSV를 활용한 입력값 관리, 키클록 등 오픈소스 연동, 멀티 리전 환경 구성까지 실제 업무에 적용 가능한 예제를 담았다. 테라폼을 더 깊이 이해하고 안정적으로 운영하고 싶은 사람에게 이 책은 훌륭한 출발점이 되어줄 것이다.

 

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

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

 

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

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

 

출판사 제이펍
저작권사 제이펍
원서명 (없음)
도서명 심각한 테라폼 중독입니다
부제 테라폼, 제대로 쓰고 싶은 이들을 위한 인프라 코드 가이드
지은이 홍수민, 정윤의
옮긴이 (없음)
감수자 (없음)
시리즈 (없음)
출판일 2025. 07. 17
페이지 376쪽
판 형 46배판변형(188*245*18)
제 본 무선(soft cover)
정 가 28,000원
ISBN 979-11-94587-25-5 (93000)
키워드 Terraform, 하시코프, HashiCorp, 데브옵스, DevOps, IaC, 코드형 인프라, AWS, 쿠버네티스, 키클록, 프로바이더, E2C, 아틀란티스, CI/CD
분 야 클라우드 / 시스템 관리

 

관련 사이트
■ (없음)

 

관련 시리즈

■ (없음)

 

관련 포스트

2025.06.25 - [출간 전 책 소식] - terraform plan은 초록인데, 왜 나는 불안할까

 

관련 도서

비전공자를 위한 AWS

AWS 시스템 개발 스킬업

AWS로 시작하는 인프라 구축의 정석

 

관련 파일 다운로드

https://github.com/suminhong/terraform-overdose

 

강의 보조 자료(교재로 채택하신 분들은 https://jpub.tistory.com/notice/1076을 통해 다음 자료를 요청하실 수 있습니다.)
■ 본문의 그림과 표

 

미리보기(앞부속, 본문 일부)

 

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

 

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

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

 

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

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

 

도서 소개

테라폼, 한번 써봤다면 이제는 제대로 빠져들 차례

 

IaC(코드형 인프라)는 더 이상 선택이 아니다. 실무에서 안정적이고 일관된 인프라를 운영하려면, 코드로 선언하고 관리하는 방식이 필수가 되었다. 그 중심에 있는 도구가 바로 테라폼이다. 그런데 문제는 여기서 시작된다. 테라폼 설치와 리소스 선언은 쉽다. 문제는 그다음이다. 상태 관리는 어떻게 할까? 실행 환경은 어떻게 나눌까? 모듈은 어디서부터 어떻게 쪼갤까? 테라폼을 ‘잘’ 쓰려면 단순히 선언하는 것만으로는 부족하다.

 

‘terraform apply’ 한 줄로는 실무가 굴러가지 않는다. 이 책은 문법만 훑는 입문서가 아닌, 실무에 바로 적용할 수 있는 실전형 가이드다. 왜 테라폼을 써야 하는지부터 선언만으로는 해결되지 않는 설계와 운영 방법까지 단계별로 짚어준다.

 

1부에서는 IaC의 필요성과 테라폼을 선택한 이유를 설명하고, 2부에서는 테라폼의 작동 방식, HCL 문법, 상태 파일과 커스텀 모듈의 핵심 개념을 정리한다. 3부에서는 모듈과 프로바이더 구성 방법을 중심으로 실행 환경 분리와 유효성 검사 등 실무 예제를 통해 테라폼 활용법을 설명한다.

 

4부에서는 VPC, 보안 그룹, EC2 등 AWS 인프라를 모듈 단위로 설계하고 구현하는 방법을 다룬다. 5부에서는 쿠버네티스, 헬름, 키클록 등 오픈소스 도구와의 테라폼 연동 방식을 실제 사례와 함께 소개한다. 부록에서는 기존 인프라에 테라폼을 도입할 때 주의할 점, 라이선스 변경 이슈 등 실무자라면 궁금해할 내용을 Q&A 형식으로 담았다.

 

이 책은 단순한 선언을 넘어 구조적이고 일관된 인프라를 설계하고 운영하는 방법을 알려준다. 반복은 줄이고, 다양한 환경에 유연하게 대응하며, 코드 한 줄로 인프라를 조율하는 감각을 키울 수 있다. 책을 따라가다 보면 어느새 테라폼의 효율성에 빠져 '이제 테라폼 없이는 인프라를 관리할 수 없다'고 느끼게 될 것이다.

 

대상 독자

  • 코드로 인프라를 다스리고 싶은 인프라 엔지니어
  • 자동화로 배포 스트레스를 줄이고 싶은 DevOps 엔지니어
  • 장애 없는 운영을 꿈꾸며 복구 시나리오까지 챙기는 SRE

 

주요 내용

  • 테라폼의 작동 원리와 상태 관리 이해
  • 실무에 맞춘 커스텀 모듈 설계와 활용
  • AWS 인프라 구성 자동화 예제
  • 다양한 프로바이더와 오픈소스 연동
  • 멀티 리전, 계정 환경을 위한 구조 설계
  • 테라폼 운영과 도입을 위한 실무 팁

 

지은이 소개

홍수민

카카오페이증권의 DevOps 플랫폼 개발자. AWS 파트너사, 오늘의집, 캐치테이블 등 다양한 IT 스타트업에서 밀도 높은 경험을 쌓으며 성장해왔다. 클라우드와 테라폼의 매력에 빠져 솔루션 아키텍트에서 DevOps 엔지니어로 전환했으며, 현재는 코드 기반으로 인프라 자원을 관리하고 새로운 기술을 우선적으로 검증하는 업무를 담당하고 있다. 최근에는 AI 기술에도 관심을 두고 다양한 프로젝트를 수행 중이며, 특히 카카오페이증권의 AI 챗봇 ‘춘시리’ 개발 경험을 기술 블로그를 통해 공유하기도 했다. 재미있고 새로운 기술에 끊임없이 도전하며, 오늘도 흥미로운 기술을 찾아 탐구 중이다. 현재 카카오톡 오픈채팅방을 통해 'Terraform 질문공부방'을 운영하고 있다.

 

정윤의

유저 리서치 SaaS를 서비스하는 스타트업인 디비디랩의 CTO. 최고의 개발팀을 경험하고 싶은 열망으로 오늘도 고군분투하고 있다. AWS와 오늘의집 등 국내외 다양한 규모의 조직에서 클라우드 기반의 개발과 시스템 설계를 수행하였으며, 수년간 테라폼과 같은 코드형 인프라를 기반으로 클라우드 자원을 운영해왔다. 패스트캠퍼스에서 ‘실무 장애 대응 프로세스로 끝내는 장애율 0% 서비스 운영의 모든 것’이라는 주제로 장애 대응 관련 온라인 강의를 하고 있으며, 멘토링 플랫폼 F-Lab에서는 현업 백엔드 및 DevOps 엔지니어를 대상으로 멘토로 활동하고 있다.

 

차례

추천의 글 xii

베타리더 후기 xx

시작하며 xxv

이 책에 대하여 xxviii

 

PART I 왜 테라폼인가?

CHAPTER 1 클라우드와 코드형 인프라스트럭처 3

1.1 클라우드 컴퓨팅 vs. 온프레미스 컴퓨팅 3

1.2 클라우드 네이티브 패러다임 5

1.3 클라우드 인프라의 복잡성과 관리의 어려움 6

1.4 선언형 IaC 도구의 필요성 9

 

CHAPTER 2 우리는 왜 테라폼을 쓰는가? 11

2.1 선언형 인프라 관리 11

2.2 다양한 프로바이더 12

2.3 선언형 스크립트 언어 14

2.4 하시코프 설정 언어에 대한 오해 16

 

PART II 테라폼 기본

더보기

CHAPTER 3 테라폼 작동 방식 21

3.1 테라폼 프로젝트 구조 21

3.2 테라폼 상태의 역할 22

3.3 테라폼 명령과 작동 26

3.4 테라폼 프로바이더 31

 

CHAPTER 4 테라폼 기본 문법 34

4.1 데이터 타입 34

4.2 반복문 35

4.3 조건문 42

4.4 for 표현식 44

4.5 테라폼 블록 49

4.6 테라폼 함수 59

 

CHAPTER 5 테라폼 모듈 66

5.1 모듈 사용 66

5.2 모듈 작성의 기본 구조 70

 

PART III 테라폼 기능별 실무 사례

CHAPTER 6 실행 환경 관리 79

6.1 실행 환경을 분리하지 않을 때의 문제점 79

6.2 실행 환경 분리 사례 81

6.3 테라폼 워크스페이스? 85

 

CHAPTER 7 다양한 인라인 블록 86

7.1 중첩 블록 86

7.2 다이내믹 블록 87

7.3 중첩 블록 vs. 별도 리소스 블록 90

7.4 생명주기 블록 92

 

CHAPTER 8 유효성 검사 95

8.1 검사 블록 95

8.2 생명주기 블록 96

8.3 체크 블록 98

 

CHAPTER 9 유틸리티 모듈 만들기 104

9.1 AWS의 메타데이터 가져오기 104

9.2 두 AWS 프로바이더가 동일한지 체크하기 107

9.3 리스트 내의 맵 합치기 109

 

PART IV AWS 모듈 사례

CHAPTER 10 모듈을 직접 만드는 이유와 만드는 방법 117

10.1 공개 모듈 vs. 직접 만든 모듈 117

10.2 모듈을 쉽게 만드는 방법 118

 

CHAPTER 11 YAML 파일로 관리하는 VPC 모듈 만들기 122

11.1 입력값 정하기 123

11.2 입력값을 모듈에 전달할 방법 정하기 126

11.3 모듈 만들기 130

11.4 변수 유효성 검사 149

11.5 모듈 출력값 설정 162

11.6 더 고려해볼 만한 것 163

 

CHAPTER 12 CSV 파일로 관리하는 보안 그룹 모듈 만들기 166

12.1 입력값 정하기 166

12.2 입력값을 모듈에 전달할 방법 정하기 168

12.3 모듈 만들기 174

12.4 변수 타입 유효성 186

12.5 모듈 출력값 설정 187

12.6 더 고려해볼 만한 것 187

 

CHAPTER 13 VPC와 보안 그룹 모듈의 출력값을 활용하는 EC2 모듈 만들기 189

13.1 입력값 정하기 189

13.2 입력값을 모듈에 전달할 방법 정하기 195

13.3 모듈 만들기 198

13.4 변수 유효성 검사 207

13.5 모듈 출력값 설정 217

13.6 더 고려해볼 만한 것 218

 

CHAPTER 14 다른 실행 환경의 출력값을 참조하는 네트워크 실행 환경 구성하기 220

14.1 미리 고려해야 할 점 220

14.2 실행 환경 재구성하기 221

14.3 요구사항 정리하기 223

14.4 원격 상태 설정하기 224

14.5 입력값과 전달 방식 정의하기 226

14.6 모듈 만들기 231

14.7 유효성 검사 236

14.8 모듈 출력값 설정 238

14.9 더 고려해볼 만한 것 238

 

PART V 다양한 프로바이더 활용 예제

CHAPTER 15 하시코프 공식 유틸리티 프로바이더 241

15.1 테라폼 프로바이더 티어 241

15.2 랜덤 프로바이더 242

15.3 HTTP 프로바이더 244

15.4 로컬 프로바이더 246

15.5 널 프로바이더와 terraform_data 리소스 249

15.6 그 외 252

 

CHAPTER 16 쿠버네티스 관련 프로바이더 256

16.1 쿠버네티스 프로바이더 256

16.2 헬름 프로바이더 270

16.3 커스텀 리소스과 Kubectl 프로바이더 284

 

CHAPTER 17 키클록 프로바이더로 AWS SSO 구현하기 292

17.1 테라폼 키클록 프로바이더 설정하기 294

17.2 키클록과 AWS SAML 간 연동을 위한 리소스 생성 297

17.3 키클록 그룹과 AWS IAM 역할 매핑하기 301

17.4 키클록 사용자로 AWS 로그인 테스트하기 309

17.5 더 고려해볼 만한 것 311

 

APPENDIX 테라폼 Q&A

APPENDIX A 테라폼을 사용하면서 생기는 문제는 어떻게 트러블슈팅하나요? 315

APPENDIX B 테라폼 작업할 때 팀원들과 잘 협업하는 방법이 있나요? 320

APPENDIX C 이미 존재하는 인프라 리소스를 테라폼으로 관리하고 싶어요 325

APPENDIX D 테라폼 관련 서드파티 오픈소스 도구는 어떤 걸 쓰세요? 331

APPENDIX E 테라폼의 라이선스가 변경된다고 하는데 문제없을까요? 336

 

찾아보기 339

 

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

  블로그  유튜브  인스타그램  트위터  페이스북