- Go language: github.com/hashicorp/terraform
- Protocol: http
[ 사전적 의믜 ]
Terraforming(테라포밍)은 지구가 아닌 다른 행성 및 위성, 기타 천체의 환경을 지구의 대기 및 온도 생태계와 비슷하게 바꾸어 인간이 살 수 있도록 만드는 작업으로 화성탐사 관련해서 종종 등장하는 용어입니다.
하시코프에서 이 제품의 이름을 왜 이렇게 지었을지 생각해보았습니다.
단어 뜻에서 각기 다른 모든 vendor의 인프라 환경을 비슷하게 바꾸어 서비스를 할 수 있도록 만드는 작업을 하는 도구라고 느껴집니다.
[ 특징 ]
테라폼은 Chef, Puppet, 과 같이 Infrastructure provisioning 툴로 분류할 수 있습니다.
The key features of Terraform are:
-
Infrastructure as Code: Infrastructure is described using a high-level configuration syntax. This allows a blueprint of your datacenter to be versioned and treated as you would any other code. Additionally, infrastructure can be shared and re-used. 👉 버전으로 인프라 이력관리, 인프라 공유 및 재사용
-
Execution Plans: Terraform has a "planning" step where it generates an execution plan. The execution plan shows what Terraform will do when you call apply. This lets you avoid any surprises when Terraform manipulates infrastructure.
👉 plan 단계를 거치면서 인프라에 어떤 변화가 생길지 볼 수 있음
-
Resource Graph: Terraform builds a graph of all your resources, and parallelizes the creation and modification of any non-dependent resources. Because of this, Terraform builds infrastructure as efficiently as possible, and operators get insight into dependencies in their infrastructure. 👉 모든 리소스를 그래프로 작성하고 종속되지 않은 리소스의 추가와 변경을 병렬로 처리해서 효율적으로 인프라를 구축하고 각 리소스의 의존성을 확인 할 수 있음
-
Change Automation: Complex changesets can be applied to your infrastructure with minimal human interaction. With the previously mentioned execution plan and resource graph, you know exactly what Terraform will change and in what order, avoiding many possible human errors. 👉 terraform plan, 그 결과로 나오는 resource graph로 어떤 순서로 변경이 발생할지 미리 확인할 수 있어서 휴먼에러를 많이 줄일 수 있음
[ 버전 관리 ]
다른 패키지와 마찬가지로 일정 시간이 지나면 new feature, bug fix등의 작업으로 upgrade 될것이고 그에 따라 맞춰주는 작업이 필요해집니다. 시간이 지나면 버전관리할 필요가 생기게 되는데 이때 크게 2가지 방법을 사용할 수 있습니다.
- 각 release 페이지에서 다운로드해서 alias 하여 사용
- tfenv (Terraform version manager)를 사용
[ Use cases ]
이중에서 제가 Terraform을 선택하려는 이유는
- Heroku App setup : -
- Multi-Tier Applications : API 서버, 캐싱 서버등 추가되는 레이어를 개별적으로 확장
- Self-Service Clusters : 서비스 구축과 확장한 방법들을 코드화
- Software Demos : -
- Disposable Environments : 서비스에 따라서 Dev, Stage 환경을 빠르게 구성해주었다가 폐기
- Software Defined Networking : AWS VPC 부터 네트워크 구성을 코드화
- Resource Schedulers : -
- Multi-Cloud Deployment : 관리를 단순화 시켜 대규모 멀티 클라우드 인프라 용이
'엔지니어' 카테고리의 다른 글
Cloudfront와 S3를 이용한 웹 서비스 구성 (1938) | 2021.03.10 |
---|---|
Jenkins 사용자 목록 curl로 가져오기 (1003) | 2020.12.29 |
Python3를 이용한 Tistory Authentication Code 방식 인증 (2020.09.01 변경사항 반영) (2468) | 2020.09.25 |
AWS Subnet 생성하기 (2534) | 2020.07.23 |
테넌트 (940) | 2020.07.23 |