Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to design CDK project?

recently started working on a CDK project, Wanted to have views of y'all on how to structure it. Ill lay out what I have thought.

Will be have 2 separate packages.

  1. ApplicationCommonsPackage
  2. SpecificApplicationCDKPackage(Can be many such packages), These will depend on the ApplicationCommonsPackage

The ApplicationCommonsPackage will hold all the common logic for all our applications(till now have thought of Configs, Common constructs, factory method for creating constructs)

The latter(SpecificApplicationCDKPackage) will hold configs for the constructs and will use the factory in ApplicationCommonsPackage for creating stuff.

What do you think of using factory pattern in ApplicationCommonsPackage? One issue I am facing is that I cannot expose a common interface with a generic method(or am not able to?) for the factory. The reason being every construct requires props which are of very specific type, I cannot generalise them to any or such sort as by that will lose the niceness of typescript. So am having functions like createLambda(scope: Stack, id: string, props: LambdaProps): Function in my factory. I am not liking this structure a lot, I would have loved generic function which took the Function as an input and would have determined the type of props from it. Something like create<T>(scope: Stack, id: string, props: <U derived from T => some methodology to get this?>): T so that when I actually use this in SpecificApplicationCDKPackage like so - this.factory.create<Function>(this, 'SampleLambda', {}) I get all compile time errors for the props parameter({})

like image 674
Michelle Avatar asked Oct 24 '25 05:10

Michelle


1 Answers

While working with aws-cdk it is important to keep in mind how we gather resources into Stacks. Once you put a resource into a cdk Stack, which then maps to CloudFormation Stack, it may be more involved to move it to a different stack after an initial production deployment.

The best way to decide if two resources should be in the same stack is to apply module design heuristic. In other words it is better if resources have more coupling within a Stack (module) than across different Stacks (modules).

For example we very often have a database (e.g. RDS) and some service connecting to it. The service when communicating with database needs its hostname, username, password and the database needs to allow that on the AWS Security Group level. Thus the number of references between a service and database is high and they should likely live inside single module (CDK Stack).

On the other side, if we have 2 services, which communicate with each other via http then one service may only need to know other service DNS name. In such case the 2 services may be better suited to live in separate Stacks.

We obviously can have helper libraries that aid creating common constructs. However, it is important to remember that objects constructed in cdk map to AWS resources. Once CDK app is deployed an innocent looking refactoring may result in resources being replaced in subsequent deploys.

like image 200
miensol Avatar answered Oct 25 '25 18:10

miensol



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!