Advanced Terraform
20 February 2018
Stoyan Stoyanov
welt.de
Who are we?
- https://www.welt.de
- 150M Visits per Month and growing
- Fastest newspaper site in Germany
whoami
data:image/s3,"s3://crabby-images/59ede/59ede1c94bc04cfd048679b8f677145c83c79277" alt=""
Structure
- Cross-functional teams
- Every team has its own AWS Account
- You build it, you own it
Tech Jungle
data:image/s3,"s3://crabby-images/c3594/c3594a87947d603b22d3deb23ef663773056b5d2" alt=""
Motivation?
- increase automation awareness
- reducing complexity
How our infrastructure code evolved
- From bash to Chef
- From private cloud to public cloud
- From AWS CloudFormation to HashiCorp Terraform
Workflow
The State
- Snapshot of the infrastructure
- Can be local or remote with different backends
data:image/s3,"s3://crabby-images/43a3d/43a3d48c28db7661a6d5e259a4134fcd085c9bb4" alt=""
The State
The State
- Outputs can be shared between "stacks" via remote states
Complexity
Centralized applying
The wrapper
Plan every hour
DRY
Versioning
Responsibility
Conventions
KISS
- Avoid config management
- user data not enough?
- Use container orchestration for the apps
Do not reinvent the wheel
- If for some reason there is no resource for the job
- local-exec + awscli
Roundup
- With great power comes great responsibility
- Updates hurt sometimes :)
data:image/s3,"s3://crabby-images/5d1a3/5d1a3e39e83db9094f6c0ad0c377a77f14c46def" alt=""
Advanced Terraform 20 February 2018 Stoyan Stoyanov welt.de
Advanced Terraform
By Stoyan Stoyanov
Advanced Terraform
- 1,342