登录
首页 >  Golang >  Go问答

使用 Pulumi 在具有 UserData 的 EC2 实例上挂载 EFS 文件系统

来源:stackoverflow

时间:2024-02-17 11:33:22 497浏览 收藏

小伙伴们对Golang编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《使用 Pulumi 在具有 UserData 的 EC2 实例上挂载 EFS 文件系统》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

问题内容

我一直在努力如何在使用 userdata 字段创建时将 efs 卷挂载到 ec2 实例。我正在使用 pulumi 的 go 库,我所拥有的内容如下所示:

// ... EFS with proper security groups and mountTarget created above ...

dir := configuration.Deployment.Efs.MountPoint
availabilityZone := configuration.Deployment.AvailabilityZone
region := configuration.Deployment.Region

userdata := args.Efs.ID().ToStringOutput().ApplyT(func(id string) (string, error) {
    script := `
            #!/bin/bash -xe
            exec > >(tee /var/log/user-data.log|logger -t user-data -s 2>/dev/console) 2>&1

            mkdir -p %s
            echo "%s.%s.%s.amazonaws.com:/ %s nfs4 nfsvers=4.1,rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2,noresvport,_netdev 0 0" | tee -a /etc/fstab
            mount -a
            `
    return fmt.Sprintf(script, dir, availabilityZone, id, region, dir), nil
}).(pulumi.StringOutput)


ec2, err := ec2.NewInstance(ctx, fmt.Sprintf("%s_instance", name), &ec2.InstanceArgs{
    // ... (other fields) ...
    UserData: userdata,
    // ... (other fields) ...
})

但是当我使用 pulumi 创建所有资源时,userdata 脚本根本不运行。我的假设是,在创建 ec2 实例时 efs id 尚未及时解析,但我认为 pulumi 会自动处理依赖关系排序,因为 ec2 实例现在依赖于 efs 卷。我还添加了一个显式的 dependson() 以查看这是否可能是问题所在,但它没有帮助。

我是不是做错了什么?任何帮助将不胜感激,谢谢!

我尝试了上述示例的几种变体。我查看了这个示例:pulumi - efs id 输出到 ec2 launchconfiguration userdata

但也无法让它发挥作用。


正确答案


我能够弄清楚,问题最终归结为以下几件事:

  1. 内联脚本的格式不需要包含制表符。
  2. pulumi.sprintf() 最终比使用 applyt() 工作得更好。
  3. 尝试执行 mount -a 时,efs 卷尚未准备好装载。

放在一起,现在看起来像这样:

instanceArgs := &ec2.InstanceArgs{
    // ... arg fields ...
}
script := `#!/bin/bash
exec > >(tee /var/log/user-data.log|logger -t user-data -s 2>/dev/console) 2>&1
mkdir -p %s
echo "%s.efs.%s.amazonaws.com:/ %s nfs4 nfsvers=4.1,rsize=1048576,wsize=1048576,hard,timeo=600,retrans=2,noresvport,_netdev 0 0" >> /etc/fstab
EFS_STATUS="unknown"
WAIT_TIME=10
RETRY_CNT=15
while [[ $EFS_STATUS != "\"available\"" ]]; do
  echo "Waiting for EFS to start..."
  sleep $WAIT_TIME
  EFS_STATUS=$(aws efs describe-file-systems | jq '.FileSystems | map(select(.FileSystemId == "%s")) |  map(.LifeCycleState) | .[0]')
done
while true; do
  mount -a -t nfs4
  if [ $? = 0 ]; then
    echo "Successfully mounted EFS to instance."
    break
  fi;
  if [ $RETRY_CNT -lt 1 ]; then
    echo "EFS could not mount after $RETRY_CNT retries."
  fi;
  echo "EFS could not mount, retrying..."
  ((RETRY_CNT--))
  sleep $WAIT_TIME
done`

userData := pulumi.Sprintf(script, mountDir, Efs.ID(), region, mountDir, Efs.ID())
instanceArgs.UserData = userData

ec2, err := ec2.NewInstance(ctx, fmt.Sprintf("%s_instance", name), instanceArgs)

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>