Abstract
- There is question, How does ACK relate to cdk8s?
- Answer: All of the ACK controllers watch for specific CRs and you can generate those resources using cdk8s. The two projects complement each other. cdk8s can create the Kubernetes resources and ACK uses those resources to create the AWS infrastructure.
- This post gives example of generating kubernetes manifest of ACK using cdk8s typescript
Table Of Contents
- Pre-requisite
- Init cdk8s-app projen
- Import ACK CRDS As CDK8S API
- Get your hands dirty with code now
- Build manifest
- Conclusion
π Pre-requisite
- This post expects you have knowledge of ACK and cdk8s.
- You can base on the AWS Controllers for Kubernetes Hands-on to test the generated manifests by cdk8s
- projen is a plus
π Init cdk8s-app projen
- You can just init cdk8s project using
cdk8s init typescript-app
but following is used projen to mange configuration through code - Init
cdk8s-app-ts
with projen in typescript. ```
β‘ $ projen new cdk8s-app-ts --projenrc-ts
- cdk8s import
β‘ $ cdk8s import --language typescript --output src/imports
Importing k8s v1.22.0...
Importing resources, this may take a few moments...
k8s
## π **Import ACK CRDS As CDK8S API** <a name="Import-ACK-CRDS-As-CDK8S-API"></a>
- [s3-controller crds](https://github.com/aws-controllers-k8s/s3-controller/tree/main/helm/crds)
β‘ $ cdk8s import https://raw.githubusercontent.com/aws-controllers-k8s/s3-controller/main/helm/crds/s3.services.k8s.aws_buckets.yaml --output src/imports/
Importing resources, this may take a few moments...
s3.services.k8s.aws
s3.services.k8s.aws/bucket
- [rds-controller crds](https://github.com/aws-controllers-k8s/rds-controller/tree/main/helm/crds), rename file from `rds.services.k8s.aws.ts` to `rds.services.db.instance.k8s.aws.ts` after import due to that name is assigned for all CRDS with in the `rds-controller` crds
β‘ $ cdk8s import https://raw.githubusercontent.com/aws-controllers-k8s/rds-controller/main/helm/crds/rds.services.k8s.aws_dbinstances.yaml --output src/imports/
Importing resources, this may take a few moments...
rds.services.k8s.aws
rds.services.k8s.aws/dbinstance
β‘ $ mv src/imports/rds.services.k8s.aws.ts src/imports/rds.services.db.instance.k8s.aws.ts
- RDS subnet group, rename file from `rds.services.k8s.aws.ts` to `rds.services.subnet.group.k8s.aws.ts`
β‘ $ cdk8s import https://raw.githubusercontent.com/aws-controllers-k8s/rds-controller/main/helm/crds/rds.services.k8s.aws_dbsubnetgroups.yaml --output src/imports/
Importing resources, this may take a few moments...
rds.services.k8s.aws
rds.services.k8s.aws/dbsubnetgroup
β‘ $ mv src/imports/rds.services.k8s.aws.ts src/imports/rds.services.subnet.group.k8s.aws.ts
## π **Get your hands dirty with code now** <a name="Get-your-hands-dirty-with-code-now"></a>
- [RDS](https://github.com/vumdao/aws-cdk8s-ack-cr/src/rds)
rds
βββ constants.ts
βββ db-instance.ts
βββ subnet-group.ts
- DBInstance requires subnet group which contains private subnets in EKS VPC (`subnet-group.ts`) and secret keys to hold user credential. The k8s secret is not generated through code here.
- `db-instance.ts` defines specs of `DbInstance`
- [S3](https://github.com/vumdao/aws-cdk8s-ack-cr/src/s3)
s3
βββ constants.ts
βββ s3.ts
## π **Build manifest** <a name="Build-manifest"></a>
- Just run `yarn build`
β‘ $ yarn build
yarn run v1.22.15
warning ../../../package.json: No license field
$ npx projen build
πΎ build Β» default | ts-node --project tsconfig.dev.json .projenrc.ts
πΎ build Β» compile | tsc --build
πΎ build Β» post-compile Β» synth | cdk8s synth
No manifests synthesized
πΎ build Β» test | jest --passWithNoTests --all --updateSnapshot
No tests found, exiting with code 0
----------|---------|----------|---------|---------|-------------------
File | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s
----------|---------|----------|---------|---------|-------------------
All files | 0 | 0 | 0 | 0 |
----------|---------|----------|---------|---------|-------------------
πΎ build Β» test Β» eslint | eslint --ext .ts,.tsx --fix --no-error-on-unmatched-pattern src test build-tools .projenrc.js
Done in 25.90s.
- Output directory
dist
βββ rds
β βββ rds-db-instance.yaml
β βββ rds-subnet-group.yaml
βββ s3
βββ s3-test-bucket.yaml
- We can now use the `yaml` files to create the AWS infrastructure through ACK
## π **Conclusion** <a name="Conclusion"></a>
- Although we have to import ACK CRDS resources for cdk8s API, we can manage k8s manifests through code
---
Top comments (1)
thank you :D