Циклическая зависимость в стеке aws из-за частного IP-адреса [AWS CloudFormation]

Я использую шаблон cloudformation для создания экземпляра EC2. В разделе пользовательских данных мне нужно запустить файл оболочки, который я создал в метаданных. Для этого файла оболочки я передаю частный IP-адрес экземпляра в качестве параметра. Чтобы получить частный IP, я использую это:

{
    "Fn::GetAtt" : [ "ConsoleServer", "PrivateIp" ]
},      

я прошу обработчик ожидания подождать, пока мои пользовательские данные будут выполнены, но обработчик ожидания зависит от EC2, который я пытаюсь настроить.

Это вызывает циклическую зависимость, но я не могу понять, как получить частный IP-адрес экземпляра другим способом?

Ниже приведена важная часть: Metadata

 "Resources": {
        "ConsoleServer": {
            "Type": "AWS::EC2::Instance",
            "Metadata": {
                "AWS::CloudFormation::Init": {
                    "config": {
                        "files": {
                            "/usr/local/share/deployment-script.sh": {
                                "mode": "755",
                                "owner": "ec2-user",
                                "group": "ec2-user",
                                "content": {
                                    "Fn::Join": [
                                        "",
                                        [
                                            "#!/bin/bash\n",
                                            "sh master.sh ",
                                            {
                                                "Ref": "S3ConsoleZip"
                                            }, " ",
                                            {
                                                "Fn::GetAtt" : [ "ConsoleServer", "PrivateIp" ]
                                            },

и это мой раздел userdata, за которым следует waithandler

 "UserData": {
                    "Fn::Base64": {
                        "Fn::Join": [
                            "",
                            [
                                "#!/bin/bash -v\n",
                                "sudo su",
                                "\n",
                                "chmod -R 775 /usr/local/share\n",

                                "yum update -y aws-cfn-bootstrap\n",
                                "## Error reporting helper function\n",
                                "function error_exit\n",
                                "{\n",
                                "   /opt/aws/bin/cfn-signal -e 1 -r \"$1\" '",
                                {
                                    "Ref": "WaitHandleServer"
                                },
                                "'\n",
                                "   exit 1\n",
                                "}\n",
                                "## Initialize CloudFormation bits\n",
                                "/opt/aws/bin/cfn-init -v -s ",
                                {
                                    "Ref": "AWS::StackName"
                                },
                                " -r ConsoleServer",
                                "   --region ",
                                {
                                    "Ref": "AWS::Region"
                                },
                                " > /tmp/cfn-init.log 2>&1 || error_exit $(</tmp/cfn-init.log)\n",
                                "cd /usr/local/share\n",
                  *********              "sh deployment-script.sh >> /home/ec2-user/deployment-script.log\n",
                                "/opt/aws/bin/cfn-signal",
                                " -e 0",
                                " '",
                                {
                                    "Ref": "WaitHandleServer"
                                },
                                "'",
                                "\n",
                                "date > /home/ec2-user/stoptime"
                            ]
                        ]
                    }
                }
            }
        },
        "WaitHandleServer": {
            "Type": "AWS::CloudFormation::WaitConditionHandle"
        },
        "WaitConditionServer": {
            "Type": "AWS::CloudFormation::WaitCondition",
            "DependsOn": "ConsoleServer",
            "Properties": {
                "Handle": {
                    "Ref": "WaitHandleServer"
                },
                "Timeout": "1200"
            }
        }
    },

я добавил *********, где вызов осуществляется из раздела данных пользователя


person Subham Tripathi    schedule 31.07.2015    source источник


Ответы (1)


Чтобы получить IP-адрес EC2, вы можете получить его, вызвав этот API, используя curl внутри вашего скрипта:

curl http://169.254.169.254/latest/meta-data/local-ipv4

Подробнее о метаданных экземпляра и данных пользователя.

person Edward Samuel    schedule 31.07.2015
comment
Наконец-то есть решение, спасибо, я не могу выразить свою благодарность словами. Большое спасибо. - person Subham Tripathi; 31.07.2015