如何使用 AWS CDK 将 EFS 连接并装载到我的 EC2 实例

Wes*_*eek 1 amazon-ec2 amazon-web-services aws-cdk

我想自动安装EFS到我EC2 instance使用的 AWS CDK。

我创建了文件系统:

        self.file_system = efs.FileSystem(
            scope=self,
            id="Efs",
            vpc=self.vpc,
            file_system_name="EFS",
            removal_policy=RemovalPolicy.DESTROY,
        )
Run Code Online (Sandbox Code Playgroud)

和 EC2 实例:

        self.ec2_instance = ec2.Instance(
            scope=self,
            id="ec2Instance",
            instance_name="my_ec2_instance",
            instance_type=ec2.InstanceType.of(
                instance_class=ec2.InstanceClass.BURSTABLE2,
                instance_size=ec2.InstanceSize.MICRO,
            ),
            machine_image=ec2.AmazonLinuxImage(
                generation=ec2.AmazonLinuxGeneration.AMAZON_LINUX_2
            ),
            vpc=self.vpc,
            vpc_subnets=ec2.SubnetSelection(subnet_type=ec2.SubnetType.PUBLIC),
            key_name="ec2-key-pair",
            security_group=ec2_security_group,
        )
Run Code Online (Sandbox Code Playgroud)

现在我需要做什么才能将它们连接起来?我看到很多在控制台上执行此操作的示例,但到目前为止我还没有找到在 AWS CDK 中执行此操作的方法。

Lau*_*Lau 7

创建 EFS 和 EC2 后,您只需在创建的 EFS 上调用 connect 即可:

file_system.connections.allow_default_port_from(instance)
Run Code Online (Sandbox Code Playgroud)

在你的情况下:

self.file_system.connections.allow_default_port_from(self.ec2_instance)
Run Code Online (Sandbox Code Playgroud)

这是文档: https://docs.aws.amazon.com/cdk/api/v1/python/aws_cdk.aws_efs/README.html#connecting

如果需要在启动时挂载,可以通过ec2的用户数据执行代码:

file_system.connections.allow_default_port_from(instance)

instance.user_data.add_commands("yum check-update -y", "yum upgrade -y", "yum install -y amazon-efs-utils", "yum install -y nfs-utils", "file_system_id_1=" + file_system.file_system_id, "efs_mount_point_1=/mnt/efs/fs1", "mkdir -p "${efs_mount_point_1}"", "test -f "/sbin/mount.efs" && echo "${file_system_id_1}:/ ${efs_mount_point_1} efs defaults,_netdev" >> /etc/fstab || " + "echo "${file_system_id_1}.efs." + Stack.of(self).region + ".amazonaws.com:/ ${efs_mount_point_1} nfs4 nfsvers=4.1,rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2,noresvport,_netdev 0 0" >> /etc/fstab", "mount -a -t efs,nfs4 defaults")
Run Code Online (Sandbox Code Playgroud)

此处的文档片段: https://docs.aws.amazon.com/cdk/api/v1/python/aws_cdk.aws_efs/README.html#mounting-the-file-system-using-user-data