繁体   English   中英

如何配置 AWS CDK 账户和区域以查找 VPC

[英]How to configure AWS CDK Account and Region to look up a VPC

我正在学习 AWS CDK,这是一个我似乎无法弄清楚的问题。 JS/Node 不是我经常使用的语言,所以如果我缺少一些明显的原生东西,请不要太苛刻。 我正在尝试将容器部署到现有 VPC/新 ECS 集群。 下面的代码不是我的整个脚本,而是一个重要的部分。 希望它给出了我正在尝试做的事情的想法。

//import everything first

stack_name = "frontend";

class Frontend extends core.Stack {
constructor(scope, id, props = {}) {
    super(scope, id);

    console.log("env variable " + JSON.stringify(props));
    
    const base_platform = new BasePlatform(this, id, props);

    //this bit doesn't matter, I'm just showing the functions I'm calling to set everything up

    const fargate_load_balanced_service = ecs_patterns.ApplicationLoadBalancedFargateService();
    this.fargate_load_balanced_service.taskDefinition.addToTaskRolePolicy();
    this.fargate_load_balanced_service.service.connections.allowTo();
    const autoscale = this.fargate_load_balanced_service.service.autoScaleTaskCount({});
    this.autoscale.scale_on_cpu_utilization();
    }
}

class BasePlatform extends core.Construct {
constructor(scope, id, props = {}) {
    super(scope, id);
    this.environment_name="frontend";
    
    console.log("environment variables " + JSON.stringify(process.env));

    //This bit is my problem child

    const vpc = ec2.Vpc.fromLookup(
        this, "VPC",{
        vpcId: 'vpc-##########'
    });

    //this bit doesn't matter, I'm just showing the functions I'm calling to set everything up

    const sd_namespace = service_discovery.PrivateDnsNamespace.from_private_dns_namespace_attributes();
    const ecs_cluster = ecs.Cluster.from_cluster_attributes();
    const services_sec_grp = ec2.SecurityGroup.from_security_group_id();
    }
}

const app = new core.App();

_env = {account: process.env.CDK_DEFAULT_ACCOUNT, region: process.env.CDK_DEFAULT_REGION };

new Frontend(app, stack_name, {env: _env});

app.synth();

当我运行 CDK 合成器时,它会吐出:

错误:无法从上下文提供程序 vpc-provider 检索值,因为未在堆栈级别指定帐户/区域。 在定义堆栈时使用显式帐户和区域配置“env”,或使用环境变量“CDK_DEFAULT_ACCOUNT”和“CDK_DEFAULT_REGION”从 CLI 继承环境信息(不推荐用于生产堆栈)

但我不知道为什么。 我在这里的用法符合 Stackoverflow 对类似问题的其他几个答案,它与 AWS 文档中的示例相似,当我使用 console.log(process.env) 时,它会吐出 CDK_DEFAULT_REGION 和 CDK_DEFAULT_ACCOUNT 的正确/预期值。 当我记录“env”时,它也会吐出预期值。

所以我的问题是,如何配置我的环境以便 ec2.Vpc.fromLookup 知道我的帐户信息,或者如何将值正确传递给“env”?

据我了解,如果您想在合成时使用环境细节,则必须 明确指定一个环境

AWS CDK 区分根本不指定 env 属性和使用 CDK_DEFAULT_ACCOUNT 和 CDK_DEFAULT_REGION 指定它。 前者意味着堆栈应该合成一个与环境无关的模板。 在此类堆栈中定义的构造不能使用有关其环境的任何信息。 例如,您不能编写 if (stack.region === 'us-east-1') 之类的代码或使用 Vpc.fromLookup (Python: from_lookup) 之类的框架工具,它们需要查询您的 AWS 帐户。 如果没有指定明确的环境,这些功能根本无法工作; 要使用它们,您必须指定 env。

如果您想与 cli 共享环境变量,您可以这样做:

new MyDevStack(app, 'dev', { 
  env: { 
    account: process.env.CDK_DEFAULT_ACCOUNT, 
    region: process.env.CDK_DEFAULT_REGION 
}});

最简单的方法是使用 aws cli( aws configure )。

您需要对您的用户进行编程访问并从 aws 控制台生成访问密钥。 AWS CDK 文档需要来自 cdk 文档的屏幕截图

由于我无法发表评论,我在这里发布我的查询。

从它的外观来看,只有一个堆栈frontend 所以我相信你也可以尝试在代码中硬编码 account-id 和 region ,看看它是否有效。 我也很好奇输出是什么

console.log("environment variables " + JSON.stringify(process.env));

尼克考克斯所述,将带有env的道具显式传递给父构造构造函数

 class BasePlatform extends core.Construct { constructor(scope, id, props = {}) { super(scope, id, props);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM