@keptn/keptn-controlplane-eks-blueprints-addon
v0.5.0
Published
Keptn Control Plane Addon for AWS EKS Blueprints
Downloads
10
Keywords
Readme
Keptn Control Plane Add-On for the Amazon EKS Blueprints
The Keptn Add-On for the Amazon EKS Blueprints enables platform administrators to install a keptn Control Plane (by default in version 0.13.4) during the bootstrapping process of an EKS cluster.
Therefore, this Add-On installs the Keptn Helm Chart and configures Keptn to use an API-Token and Bridge Password with credentials specified by variables or a Amazon Secrets Manager Secret.
AWS Secret Manager Secrets
If you plan to use Secret Manager Secrets, you need to create a secret first.
Therefore:
- Open your AWS Console
- Search for "Secrets Manager"
- Create a new secret ("Store a new secret")
- Secret Type: "Other type of secret"
- Key/value pairs
- API_TOKEN=""
- BRIDGE_PASSWORD=""
- Remember the name you assigned to the secret
Usage
The Add-On can be used by either specifying the name of a Secrets Manager secret or the API Token and Bridge password.
You can find informations how to get started with EKS Blueprints Projects here.
Example Configuration (secrets in Secrets Manager):
import 'source-map-support/register';
import * as cdk from 'aws-cdk-lib';
import * as blueprints from '@aws-quickstart/eks-blueprints';
import { KeptnControlPlaneAddOn } from '@keptn/keptn-controlplane-eks-blueprints-addon'
const app = new cdk.App();
const account = '<AWS ACCOUNT ID>';
const region = '<AWS REGION>';
const KeptnControlPlane = new KeptnControlPlaneAddOn({
ssmSecretName: 'keptn-ssp',
})
blueprints.EksBlueprint.builder()
.account(account)
.region(region)
.addOns(new blueprints.addons.CalicoAddOn)
.addOns(new blueprints.addons.MetricsServerAddOn,)
.addOns(new blueprints.addons.ClusterAutoScalerAddOn)
.addOns(new blueprints.addons.ContainerInsightsAddOn)
.addOns(new blueprints.addons.AwsLoadBalancerControllerAddOn())
.addOns(new blueprints.addons.VpcCniAddOn())
.addOns(new blueprints.addons.CoreDnsAddOn())
.addOns(new blueprints.addons.KubeProxyAddOn())
.addOns(new blueprints.addons.XrayAddOn())
.addOns(KeptnControlPlane)
.build(app, 'eks-blueprint');
Example Configuration (secrets in code):
import 'source-map-support/register';
import * as cdk from 'aws-cdk-lib';
import * as blueprints from '@aws-quickstart/eks-blueprints';
import { KeptnControlPlaneAddOn } from '@keptn/keptn-controlplane-eks-blueprints-addon'
const app = new cdk.App();
const account = '<AWS ACCOUNT ID>';
const region = '<AWS REGION>';
const KeptnControlPlane = new KeptnControlPlaneAddOn({
apiToken: '<your-api-token>',
bridgePassword: '<your-bridge-password>'
})
blueprints.EksBlueprint.builder()
.account(account)
.region(region)
.addOns(new blueprints.addons.CalicoAddOn)
.addOns(new blueprints.addons.MetricsServerAddOn,)
.addOns(new blueprints.addons.ClusterAutoScalerAddOn)
.addOns(new blueprints.addons.ContainerInsightsAddOn)
.addOns(new blueprints.addons.AwsLoadBalancerControllerAddOn())
.addOns(new blueprints.addons.VpcCniAddOn())
.addOns(new blueprints.addons.CoreDnsAddOn())
.addOns(new blueprints.addons.KubeProxyAddOn())
.addOns(new blueprints.addons.XrayAddOn())
.addOns(KeptnControlPlane)
.build(app, 'eks-blueprint');
Add-On Options
|Name |Type |Default |Description |----------------|---------|----------------------------|------------------------------------ | ssmSecretName | string | | The AWS Secrets Manager Secret which is containing the Keptn bridge password and API Token (keys: API_TOKEN, BRIDGE_PASSWORD) | apiToken | string | | Keptn API Token is used to connect to the Keptn API, not needed if a ssmSecretName is specified | bridgePassword | string | | Keptn Bridge Password is used to login to the Keptn bridge, not needed if a ssmSecretName is specified | namespace | string | keptn | Namespace where the keptn Control Plane will be deployed | helmrepo | string | https://storage.googleapis.com/keptn-installer | Helm Repository which will be used for installing Keptn | version | string | 0.11.4 | The Version of Keptn which should get installed | enableLoadbalancer | boolean | false | Expose Keptn's Bridge and API Gateway service as type Loadbalancer instead of ClusterIP | enableIngress | boolean | false | Create an Ingress object to Expose Keptn's Bridge and API Gateway | ingressHostname | string | | The Hostname for the Ingress object | ingressAnnotations | object | | Add additional Ingress Annotations like the ingress class | ingressSecretName | string | | Configure an ingress secretName
Extended Examples
Example Configuration (create Ingress):
const KeptnControlPlane = new KeptnControlPlaneAddOn({
ssmSecretName: 'keptn-secrets',
enableIngress: true,
ingressHostname: 'mykeptn.yourdomain.com',
ingressAnnotations: {
"kubernetes.io/ingress.class": "nginx"
},
ingressSecretName: 'mytlssecret'
})
Example Configuration (expose Bridge via Loadbalancer):
const KeptnControlPlane = new KeptnControlPlaneAddOn({
ssmSecretName: 'keptn-secrets',
enableLoadbalancer: true
})
Enhancements / Bugs
You are welcome to use issues to report bugs or request enhancements.