Need advice about which tool to choose?Ask the StackShare community!
Docker vs Terraform: What are the differences?
Docker is a containerization platform that simplifies the process of packaging and deploying applications, while Terraform is an infrastructure as code tool used for provisioning and managing cloud resources in a declarative manner. Let's explore the key differences between them.
Container Orchestration vs Infrastructure Provisioning: Docker is primarily used for containerization and container orchestration. It allows developers to package their applications and their dependencies into containers, making it easy to deploy and manage them across different environments. Terraform, on the other hand, is an infrastructure provisioning tool. It enables users to define and provision infrastructure resources, such as servers, networks, and storage, in a way that can be easily managed and automated.
Scope: Docker focuses on the deployment and management of applications within containers. It provides a lightweight runtime environment that is isolated from the underlying operating system, making it easier to develop and deploy applications. Terraform, on the other hand, focuses on the provisioning and management of infrastructure resources. It allows users to define and provision infrastructure as code, enabling consistent and repeatable deployments.
Technology Stack: Docker is built on containerization technology, using containers to package and distribute applications and their dependencies. It relies on a container runtime engine, such as Docker Engine, to run these containers. Terraform, on the other hand, is a cloud-agnostic technology. It can be used to provision infrastructure resources on a wide range of cloud providers, including AWS, Azure, Google Cloud, and more.
State Management: Docker does not have a built-in state management system. Each container is isolated and runs independently. Docker containers can be managed and orchestrated using tools like Docker Compose and Kubernetes. Terraform, on the other hand, has built-in state management. It maintains a state file that keeps track of the current state of the infrastructure. This allows Terraform to understand the changes that need to be made to the infrastructure and apply them accordingly.
Use Case: Docker is commonly used for building, packaging, and deploying applications, especially in microservices architectures. It provides a lightweight and efficient way to package applications and their dependencies, making it easier to deploy and scale them. Terraform, on the other hand, is used for infrastructure provisioning and management. It enables users to define and manage infrastructure resources, making it easier to automate infrastructure deployments and ensure consistency across environments.
Community Support and Ecosystem: Docker has a large and active community with a wide range of tools and libraries built around it. This includes popular tools like Docker Compose, Docker Swarm, and Kubernetes, which provide additional functionality for managing and orchestrating Docker containers. Terraform also has a strong community and ecosystem, with support for a wide range of cloud providers and resources. It integrates well with other infrastructure tools and frameworks, making it easy to use alongside existing workflows and technologies.
In summary, Docker focuses on container orchestration and application deployment, while Terraform focuses on infrastructure provisioning and management. Docker uses containers to package and distribute applications, while Terraform provides infrastructure as code for provisioning and managing resources. Docker is commonly used for building and deploying applications, while Terraform is used for automating and managing infrastructure deployments.
Ok, so first - AWS Copilot is CloudFormation under the hood, but the way it works results in you not thinking about CFN anymore. AWS found the right balance with Copilot - it's insanely simple to setup production-ready multi-account environment with many services inside, with CI/CD out of the box etc etc. It's pretty new, but even now it was enough to launch Transcripto, which uses may be a dozen of different AWS services, all bound together by Copilot.
Because Pulumi uses real programming languages, you can actually write abstractions for your infrastructure code, which is incredibly empowering. You still 'describe' your desired state, but by having a programming language at your fingers, you can factor out patterns, and package it up for easier consumption.
We use Terraform to manage AWS cloud environment for the project. It is pretty complex, largely static, security-focused, and constantly evolving.
Terraform provides descriptive (declarative) way of defining the target configuration, where it can work out the dependencies between configuration elements and apply differences without re-provisioning the entire cloud stack.
AdvantagesTerraform is vendor-neutral in a way that it is using a common configuration language (HCL) with plugins (providers) for multiple cloud and service providers.
Terraform keeps track of the previous state of the deployment and applies incremental changes, resulting in faster deployment times.
Terraform allows us to share reusable modules between projects. We have built an impressive library of modules internally, which makes it very easy to assemble a new project from pre-fabricated building blocks.
DisadvantagesSoftware is imperfect, and Terraform is no exception. Occasionally we hit annoying bugs that we have to work around. The interaction with any underlying APIs is encapsulated inside 3rd party Terraform providers, and any bug fixes or new features require a provider release. Some providers have very poor coverage of the underlying APIs.
Terraform is not great for managing highly dynamic parts of cloud environments. That part is better delegated to other tools or scripts.
Terraform state may go out of sync with the target environment or with the source configuration, which often results in painful reconciliation.
I personally am not a huge fan of vendor lock in for multiple reasons:
- I've seen cost saving moves to the cloud end up costing a fortune and trapping companies due to over utilization of cloud specific features.
- I've seen S3 failures nearly take down half the internet.
- I've seen companies get stuck in the cloud because they aren't built cloud agnostic.
I choose to use terraform for my cloud provisioning for these reasons:
- It's cloud agnostic so I can use it no matter where I am.
- It isn't difficult to use and uses a relatively easy to read language.
- It tests infrastructure before running it, and enables me to see and keep changes up to date.
- It runs from the same CLI I do most of my CM work from.
Context: I wanted to create an end to end IoT data pipeline simulation in Google Cloud IoT Core and other GCP services. I never touched Terraform meaningfully until working on this project, and it's one of the best explorations in my development career. The documentation and syntax is incredibly human-readable and friendly. I'm used to building infrastructure through the google apis via Python , but I'm so glad past Sung did not make that decision. I was tempted to use Google Cloud Deployment Manager, but the templates were a bit convoluted by first impression. I'm glad past Sung did not make this decision either.
Solution: Leveraging Google Cloud Build Google Cloud Run Google Cloud Bigtable Google BigQuery Google Cloud Storage Google Compute Engine along with some other fun tools, I can deploy over 40 GCP resources using Terraform!
Check Out My Architecture: CLICK ME
Check out the GitHub repo attached
lxd/lxc and Docker aren't congruent so this comparison needs a more detailed look; but in short I can say: the lxd-integrated administration of storage including zfs with its snapshot capabilities as well as the system container (multi-process) approach of lxc vs. the limited single-process container approach of Docker is the main reason I chose lxd over Docker.
We are in the process of building a modern content platform to deliver our content through various channels. We decided to go with Microservices architecture as we wanted scale. Microservice architecture style is an approach to developing an application as a suite of small independently deployable services built around specific business capabilities. You can gain modularity, extensive parallelism and cost-effective scaling by deploying services across many distributed servers. Microservices modularity facilitates independent updates/deployments, and helps to avoid single point of failure, which can help prevent large-scale outages. We also decided to use Event Driven Architecture pattern which is a popular distributed asynchronous architecture pattern used to produce highly scalable applications. The event-driven architecture is made up of highly decoupled, single-purpose event processing components that asynchronously receive and process events.
To build our #Backend capabilities we decided to use the following: 1. #Microservices - Java with Spring Boot , Node.js with ExpressJS and Python with Flask 2. #Eventsourcingframework - Amazon Kinesis , Amazon Kinesis Firehose , Amazon SNS , Amazon SQS, AWS Lambda 3. #Data - Amazon RDS , Amazon DynamoDB , Amazon S3 , MongoDB Atlas
To build #Webapps we decided to use Angular 2 with RxJS
#Devops - GitHub , Travis CI , Terraform , Docker , Serverless
Pros of Docker
- Rapid integration and build up823
- Isolation692
- Open source521
- Testability and reproducibility505
- Lightweight460
- Standardization218
- Scalable185
- Upgrading / downgrading / application versions106
- Security88
- Private paas environments85
- Portability34
- Limit resource usage26
- Game changer17
- I love the way docker has changed virtualization16
- Fast14
- Concurrency12
- Docker's Compose tools8
- Easy setup6
- Fast and Portable6
- Because its fun5
- Makes shipping to production very simple4
- Highly useful3
- It's dope3
- Package the environment with the application2
- Super2
- Open source and highly configurable2
- Simplicity, isolation, resource effective2
- MacOS support FAKE2
- Its cool2
- Does a nice job hogging memory2
- Docker hub for the FTW2
- HIgh Throughput2
- Very easy to setup integrate and build2
- Asdfd0
Pros of Terraform
- Infrastructure as code121
- Declarative syntax73
- Planning45
- Simple28
- Parallelism24
- Well-documented8
- Cloud agnostic8
- It's like coding your infrastructure in simple English6
- Immutable infrastructure6
- Platform agnostic5
- Extendable4
- Automation4
- Automates infrastructure deployments4
- Portability4
- Lightweight2
- Scales to hundreds of hosts2
Sign up to add or upvote prosMake informed product decisions
Cons of Docker
- New versions == broken features8
- Unreliable networking6
- Documentation not always in sync6
- Moves quickly4
- Not Secure3
Cons of Terraform
- Doesn't have full support to GKE1