Hacker News new | past | comments | ask | show | jobs | submit login
Ask HN: What's better Terraform or AWS CDK?
9 points by Kalpeshbhalekar 7 months ago | hide | past | favorite | 12 comments
If one is not planning to go multi-cloud, is CDK a better decision?



We've been using CDK for Terraform[1] for a year or two for both AWS and GCP. It's working great. We especially like that it supports Typescript.

[1] https://developer.hashicorp.com/terraform/cdktf


https://opentofu.org/ is better than terraform, as it’s a fork that happened before terraform became not open source.


I am using it for a new project as my first contact with this approach (long time Ansible user). So far it is great, both tofu cli, actual execution and vscode plugin.

But I'm curious about the providers ecosystem. Isn't that the weak link in this project? Biggest ones are actually developed by Hashicorp and not the big 3 cloud vendors. I also failed to find any independent docs on them, just a huge pile of folders in GitHub with basically no interface nor description what is what.

So while I use OpenTofu I still really fully on terraform docs.

Are there similar resources within OpenTofu project?



Terraform requires a proprietary domain-specific language (DSL) and is not open source. - This looks interesting

Won't Pulumi change its license like terraform a few years down the line?


Terraform and the CDK use different programming models to achieve similar goals. The CDK takes a more dynamic scripting approach much like Gradle, while Terraform is more descriptive and declarative. Functionally, I think they have similar capabilities.


If you plan on making your devs do all your infra work, maybe CDK would be better. But you will eventually regret not having TF and its huge ecosystem of modules and integrations.


CDK is far better if you are only on AWS and need advanced cloud setups.


I guess the vendor lock issue is not as harsh if using Terraform


It might not matter _that much_ depending on the complexity of the application you're modeling.

There are lots of options. A few things to consider:

- Is it a dedicated individual or group responsible for the IaC? What are they comfortable with? - Details about the running app will need to find their way into the infra somehow (env vars at least), if it's a separate group or individual, what will be the most obvious process to perform that exchange of information?

I wrote a short piece about point two [1]. Disclosure: I work at a company building a platform with its own opinionated IaC.

1. https://noop.dev/blog/build-apps-not-infrastructure/


Ansible


CloudFormation




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: