Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[aws-eks] Add EKS Cluster Lookup method #7825

Open
1 of 2 tasks
juanjoDiaz opened this issue May 6, 2020 · 16 comments
Open
1 of 2 tasks

[aws-eks] Add EKS Cluster Lookup method #7825

juanjoDiaz opened this issue May 6, 2020 · 16 comments
Labels
@aws-cdk/aws-eks Related to Amazon Elastic Kubernetes Service effort/medium Medium work item – several days of effort feature-request A feature should be added or improved. p1

Comments

@juanjoDiaz
Copy link

Enable EKS cluster lookups simular to VPC lookup (using only the ID or the ARN).
Currently, the closes thing is fromClusterAttributes which requires information about the VPC, the security groups, etc, which seems really unnecessary to me

export interface ClusterAttributes {
/**
* The VPC in which this Cluster was created
*/
readonly vpc: ec2.IVpc;
/**
* The physical name of the Cluster
*/
readonly clusterName: string;
/**
* The unique ARN assigned to the service by AWS
* in the form of arn:aws:eks:
*/
readonly clusterArn: string;
/**
* The API Server endpoint URL
*/
readonly clusterEndpoint: string;
/**
* The certificate-authority-data for your cluster.
*/
readonly clusterCertificateAuthorityData: string;
/**
* The security groups associated with this cluster.
*/
readonly securityGroups: ec2.ISecurityGroup[];
}

Use Case

I am creating an EKS cluster using CDK.
In a separate stack, I would like to add a Fargate profile. I have no easy way to get the cluster so I can pass it to the FargateProfile constructor.
There is no easy way to do so.

Proposed Solution

A similar solution as what's used in the VPC module

public static fromLookup(scope: Construct, id: string, options: VpcLookupOptions): IVpc {
if (Token.isUnresolved(options.vpcId)
|| Token.isUnresolved(options.vpcName)
|| Object.values(options.tags || {}).some(Token.isUnresolved)
|| Object.keys(options.tags || {}).some(Token.isUnresolved)) {
throw new Error('All arguments to Vpc.fromLookup() must be concrete (no Tokens)');
}
const filter: {[key: string]: string} = makeTagFilter(options.tags);
// We give special treatment to some tags
if (options.vpcId) { filter['vpc-id'] = options.vpcId; }
if (options.vpcName) { filter['tag:Name'] = options.vpcName; }
if (options.isDefault !== undefined) {
filter.isDefault = options.isDefault ? 'true' : 'false';
}
const attributes: cxapi.VpcContextResponse = ContextProvider.getValue(scope, {
provider: cxapi.VPC_PROVIDER,
props: {
filter,
returnAsymmetricSubnets: true,
subnetGroupNameTag: options.subnetGroupNameTag,
} as cxapi.VpcContextQuery,
dummyValue: undefined,
}).value;
return new LookedUpVpc(scope, id, attributes || DUMMY_VPC_PROPS, attributes === undefined);
/**
* Prefixes all keys in the argument with `tag:`.`
*/
function makeTagFilter(tags: { [name: string]: string } | undefined): { [name: string]: string } {
const result: { [name: string]: string } = {};
for (const [name, value] of Object.entries(tags || {})) {
result[`tag:${name}`] = value;
}
return result;
}
}

  • 👋 I may be able to implement this feature request
  • ⚠️ This feature might incur a breaking change

This is a 🚀 Feature Request

@juanjoDiaz juanjoDiaz added feature-request A feature should be added or improved. needs-triage This issue or PR still needs to be triaged. labels May 6, 2020
@SomayaB SomayaB added the @aws-cdk/aws-eks Related to Amazon Elastic Kubernetes Service label May 6, 2020
@eladb eladb added the effort/medium Medium work item – several days of effort label May 7, 2020
@SomayaB SomayaB removed the needs-triage This issue or PR still needs to be triaged. label May 19, 2020
@samuelthan
Copy link

love to see this feature.
Helps me with trying to get the default security group that was created by AWS EKS.

At the moment i'm using boto3 to pull this information which seems a bit ugly in the cdk world.

Vote +1

@juanjoDiaz
Copy link
Author

Any progress on this?

As said, I'd be happy contributing this feature but I'll probably need some guidance on how to implement it so it's consistent with the other lookups in the library.

@eladb
Copy link
Contributor

eladb commented Jun 24, 2020

Related to #8608

@eladb eladb added the p1 label Jun 24, 2020
@iliapolo iliapolo changed the title Add EKS Cluster Lookup method [aws-eks] Add EKS Cluster Lookup method Aug 16, 2020
@rcollette
Copy link
Contributor

rcollette commented Sep 11, 2020

I am having a similar issue trying add a Fargate service in a CDK application that is separate from the CDK application that creates the cluster. I'm using a combination of ssm parameters using a naming convention to store cluster properties, and Cluster.fromClusterAttributes(), but now I'm running into.

Cannot enable service discovery if a CloudMap Namespace has not been created in the cluster.

The defaultCloudMapNamespace is an object that cannot be serialized to JSON due to cyclical references and it cannot be reconstructed (or at least it seems difficult to do so) because it is not a pure interface, having properties for Stack and Node classes.

If a Cluster instance can be obtained with Cluster.fromLookup() and it's properties including the defaultCloudMapNamespace populated, it would enable creating a Fargate service with CloudMap enabled.

@sunshineo
Copy link

Our use case need to allow EKS cluster to access an RDS. We tried to have the RDS creation and allow access in a separate repository, but the EKS cluster we get from fromClusterAttributes did not work. And it failed silently

const eksCluster = eks.Cluster.fromClusterAttributes(this, 'cdk-managed-eks-cluster', { clusterName: 'cdk-managed-eks-cluster', })
const rdsCluster = new rds.DatabaseCluster(this, 'Database', {...});
rdsCluster.connections.allowFrom(eksCluster.connections, rdsPort, 'Allow eks cluster to connect to rds')

The code above works if we create the eks cluster in the same stack.

@iliapolo iliapolo removed their assignment Jun 27, 2021
@iliapolo
Copy link
Contributor

This issue has been re-classified as p2. That means a workaround is available or it is deemed a nice-to-have feature. Given the amount of work there is to do and the relative priority of this issue, the CDK team is unlikely to address it. That does not mean the issue will never be fixed! If someone from the community submits a PR to fix this issue, and the PR is small and straightforward enough, and meets the quality bars to be reviewed and merged with little effort we will accept that PR. PRs that do not build or need complex or multiple rounds of reviews are unlikely to be merged and will be closed to keep our backlog manageable.

We use +1s on this issue to help prioritize our work, and are happy to re-evaluate the prioritization of this issue based on community feedback. You can reach out to the cdk.dev community on Slack to solicit support for reprioritization.

@iliapolo iliapolo added p2 and removed p1 labels May 16, 2023
@petteriv-nordic
Copy link

@iliapolo What is the workaround you mentioned above?

@iliapolo
Copy link
Contributor

@petteriv-nordic

That means a workaround is available or it is deemed a nice-to-have feature.

This currently is classified as a nice-to-have, no workaround available.

@taabrcr
Copy link

taabrcr commented May 24, 2023

Vote +1 from my side as well, as this is a very much needed feature

@mauritz-lovgren
Copy link

When creating an ECS service in a separate CDK project from the project that deploys the ECS Cluster (typically if the latter sets up 'general aspects' for the environment and the former creates service specific resources), the defaultCloudMapNamespace created in the environment CDK project is only available to the service CDK project by knowing a lot of details of the namespace defined in the latter.

One might expect that the defaultCloudMapNamespace was available after look up of Cluster in the 'service CDK project' when using Cluster.fromClusterAttributes or Cluster.fromClusterArn?

Currently, we need to do the following when looking up the cluster to provide the namespace to an ECS service:

const cluster = ecs.Cluster.fromClusterAttributes(this, 'Cluster', {
  clusterName: clusterName,
  vpc: vpc,
  defaultCloudMapNamespace: cloudmap.PrivateDnsNamespace.fromPrivateDnsNamespaceAttributes(
      this, 'Namespace', {
        namespaceArn: Arn.format({
          service: 'servicediscovery',
          resource: 'namespace',
          resourceName: namespaceId
        }, this),
        namespaceId,
        namespaceName
      }
});

@nikolic-milan
Copy link

Hello,

has there been any progress on this? We have a use case where we have a repository that defines and sets up the cluster infrastructure, and then other repositories for different apps we want to deploy in the cluster. Currently, I can't figure out a way to add the app to the cluster from a different repository. Using the from_cluster_attributes to get the cluster, I can't perform the add_manifest operation. I tried defining the kubectl_role_arn property that is required to enable kubectl execution, but there is always an issue with the roles I add, and I tried all the roles that are connected to the cluster, which have an arn.

Am I missing something, do I need to create a specific role for this? Or is it just not currently possible?

What about the add_helm_chart method, will that work on a cluster found from arn?

Kind Regards,
Milan Nikolić

@HumbleBeck
Copy link

Hi, this might have been overlooked, but are there any plans to implement this?

@ThePlenkov
Copy link

ThePlenkov commented Oct 17, 2024

But isn't it what you've been looking for? https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.Cluster.html#static-fromwbrclusterwbrattributesscope-id-attrs

static fromClusterAttributes(scope, id, attrs)
public static fromClusterAttributes(scope: Construct, id: string, attrs: ClusterAttributes): ICluster
Parameters

scope [Construct](https://docs.aws.amazon.com/cdk/api/v2/docs/constructs.Construct.html) — the construct scope, in most cases 'this'.
id string — the id or name to import as.
attrs [ClusterAttributes](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ClusterAttributes.html) — the cluster properties to use for importing information.
Returns

[ICluster](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ICluster.html)
Import an existing cluster.

@github-actions github-actions bot added p1 and removed p2 labels Nov 24, 2024
Copy link

This issue has received a significant amount of attention so we are automatically upgrading its priority. A member of the community will see the re-prioritization and provide an update on the issue.

@ThePlenkov
Copy link

But isn't it what you've been looking for? https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.Cluster.html#static-fromwbrclusterwbrattributesscope-id-attrs

static fromClusterAttributes(scope, id, attrs)
public static fromClusterAttributes(scope: Construct, id: string, attrs: ClusterAttributes): ICluster
Parameters

scope [Construct](https://docs.aws.amazon.com/cdk/api/v2/docs/constructs.Construct.html) — the construct scope, in most cases 'this'.
id string — the id or name to import as.
attrs [ClusterAttributes](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ClusterAttributes.html) — the cluster properties to use for importing information.
Returns

[ICluster](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ICluster.html)
Import an existing cluster.

i honestly don't understand why it was downvote by peers. I see this method is importing an existing cluster. Also, ClusterAttributes need only name , rest is optional. https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ClusterAttributes.html Doesn't it work?

@nikolic-milan
Copy link

But isn't it what you've been looking for? https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.Cluster.html#static-fromwbrclusterwbrattributesscope-id-attrs

static fromClusterAttributes(scope, id, attrs)
public static fromClusterAttributes(scope: Construct, id: string, attrs: ClusterAttributes): ICluster
Parameters

scope [Construct](https://docs.aws.amazon.com/cdk/api/v2/docs/constructs.Construct.html) — the construct scope, in most cases 'this'.
id string — the id or name to import as.
attrs [ClusterAttributes](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ClusterAttributes.html) — the cluster properties to use for importing information.
Returns

[ICluster](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ICluster.html)
Import an existing cluster.

i honestly don't understand why it was downvote by peers. I see this method is importing an existing cluster. Also, ClusterAttributes need only name , rest is optional. https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_eks.ClusterAttributes.html Doesn't it work?

I tested with that, but that won't allow you to use the cluster in a meaningful way (unless they changed something in the past year or so). Basically, it imports the cluster, but It wouldn't allow me to add a manifest to it or changed it.

My use case was that we wanted to have one cluster to which we deploy all our apps, but we didn't want the apps to be in the same DevOps repo. So now, the app repository just creates a docker image and uploads it to a docker repository, then triggers the cluster repo to redeploy by using the new docker image.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
@aws-cdk/aws-eks Related to Amazon Elastic Kubernetes Service effort/medium Medium work item – several days of effort feature-request A feature should be added or improved. p1
Projects
None yet
Development

No branches or pull requests