尝试通过CloudFormation进行部署时,“部署<codeDeploy>失败。状态=失败”

时间:2020-02-03 15:00:19

标签: amazon-web-services amazon-cloudformation aws-code-deploy

我正在尝试通过CodeDeploy部署应用程序,但是随着进度的进行,堆栈最终出现错误“ Deployment d-ICC6WMBE2 failed。Status = Failed”。

没有理由提及。怎么调试一样。 提前致谢。 PFb模板,我用于部署:

Parameters:
  SSHKey:
    Type: AWS::EC2::KeyPair::KeyName
    Description: Name of an existing EC2 KeyPair to enable SSH access to the instance
  CodedeployInstanceType:
    Description: "EC2 instance type for  CodeDeploy Web Servers"
    Type: String
    Default: "t2.micro"
    ConstraintDescription: "must be a valid EC2 instance type."
  PublicSubnet1: 
    Description: "The first public subnet where the Jenkins EC2 instance, ELB and CodeDeploy Web Servers will be launched"
    Type: AWS::EC2::Subnet::Id
    ConstraintDescription: "Must be a valid Public VPC Subnet."
  PublicSubnet2: 
    Description: "The second public subnet where the ELB and CodeDeploy Web Servers will be launched"
    Type: AWS::EC2::Subnet::Id
    ConstraintDescription: "Must be a valid Public VPC Subnet."
  InstanceCount : 
    Description : "Number of CodeDeploy Web Server EC2 instances"
    Type : Number
    Default : 3
    ConstraintDescription : "Must be a number between 2 and 4."
    MinValue : "2"
    MaxValue : "4"
  VpcId: 
    Description: "The VPC Id where the EC2 instances will be launched."
    Type: AWS::EC2::VPC::Id
    ConstraintDescription: "must be the name of an existing VPC."
Mappings: 
  AWSRegionArch2AMI: 
      ap-northeast-1  : 
        AMI : "ami-08847abae18baa040" 
      ap-northeast-2  : 
        AMI : "ami-012566705322e9a8e" 
      ap-south-1        : 
        AMI : "ami-00b6a8a2bd28daf19" 
      ap-southeast-1  : 
        AMI : "ami-01da99628f381e50a" 
      ap-southeast-2    :  
        AMI : "ami-00e17d1165b9dd3ec" 
      eu-central-1  : 
        AMI : "ami-0f5dbc86dd9cbf7a8" 
      eu-west-1  : 
        AMI : "ami-0bdb1d6c15a40392c" 
      eu-west-2  : 
        AMI : "ami-e1768386" 
      eu-west-3   : 
        AMI : "ami-06340c8c12baa6a09" 
      sa-east-1  : 
        AMI : "ami-0ad7b0031d41ed4b9" 
      us-east-1  : 
        AMI :  "ami-04681a1dbd79675a5" 
      us-east-2   :
        AMI : "ami-0cf31d971a3ca20d6" 
      us-west-1  :
        AMI : "ami-0782017a917e973e7" 
      us-west-2  : 
        AMI : "ami-6cd6f714"    
Resources:
  WSSG:
   Type: AWS::EC2::SecurityGroup
   Properties:
     GroupDescription: "Enable HTTP access from ELB"
     VpcId: 
       Ref: "VpcId"
     SecurityGroupIngress:
       -
        IpProtocol: "tcp"
        FromPort: "22"
        ToPort: "22"
        CidrIp: "0.0.0.0/0"
       -
        IpProtocol: "tcp"
        FromPort: "80"
        ToPort: "80"
        SourceSecurityGroupId: 
          Ref: "ELBSG"
  ELB: 
    Type: "AWS::ElasticLoadBalancing::LoadBalancer"
    Properties:
      HealthCheck:
        HealthyThreshold: "2"
        Interval: "30"
        Target: "HTTP:80/"
        Timeout: "5"
        UnhealthyThreshold: "5"
      Listeners: 
        - InstancePort: "80"
          LoadBalancerPort: "80"
          Protocol: "HTTP"
          InstanceProtocol: "HTTP"
      Subnets: 
        - 
         Ref : "PublicSubnet1"
         Ref : "PublicSubnet2"
      SecurityGroups: 
        - 
         Ref: "ELBSG"
  ELBSG:
    Type: AWS::EC2::SecurityGroup
    Properties:
      GroupDescription: "Enable HTTP access from anywhere"
      VpcId: 
        Ref : "VpcId"
      SecurityGroupIngress: 
        - IpProtocol: "tcp"   
          FromPort: "80"
          ToPort : "80"
          CidrIp: "0.0.0.0/0"
  CodeDeployTrustRole:
    Type: AWS::IAM::Role
    Properties:
      AssumeRolePolicyDocument:
        Version: "2008-10-17"
        Statement:
          -
           Sid: "1"
           Effect: Allow
           Principal:
             Service: 
               - codedeploy.amazonaws.com
           Action: 
              - sts:AssumeRole
      Path: "/" 
  CodeDeployRolePolicies:
    Type: AWS::IAM::Policy
    Properties: 
      PolicyName: CodeDeployPolicy
      PolicyDocument :
        Statement:
          -
           Effect: Allow
           Action:
             - ec2:Describe*
             - autoscaling:CompleteLifecycleAction
             - autoscaling:DeleteLifecycleHook
             - autoscaling:DescribeLifecycleHooks
             - autoscaling:DescribeAutoScalingGroups
             - autoscaling:PutLifecycleHook
             - autoscaling:RecordLifecycleActionHeartbeat
             - Tag:getResources
             - Tag:getTags
             - Tag:getTagsForResource
             - Tag:getTagsForResourceList
           Resource: "*"
      Roles: 
        - Ref: "CodeDeployTrustRole"
  DemoApplication: 
    Type: AWS::CodeDeploy::Application 
  DemoFleet:
    Type: AWS::CodeDeploy::DeploymentGroup
    Properties:  
      ApplicationName: !Ref DemoApplication
      AutoScalingGroups: 
        - !Ref WSASG
      Deployment: 
        Description: "Initial Deployment"
        Revision: 
          RevisionType: S3
          S3Location: 
            Bucket: Fn::Join:["",["aws-codedeploy-" !Ref["AWS::Region"]]]
            BundleType: "zip"
            Key: "samples/latest/SampleApp_Linux.zip"
      DeploymentConfigName: "CodeDeployDefault.OneAtATime"
      ServiceRoleArn: 
        Fn::GetAtt: ["CodeDeployTrustRole", Arn]
  InstanceRole:
    Type: AWS::IAM::Role
    Properties: 
      AssumeRolePolicyDocument:
        Statement:
          - 
           Effect: Allow
           Principal:
             Service:
               - ec2.amazonaws.com
           Action: 
             - sts:AssumeRole               
      Path: "/"      
  CodeDeployInstanceProfile:
    Type: AWS::IAM::InstanceProfile
    Properties:
      Path: "/"
      Roles:
        - 
          Ref: "InstanceRole"
  InstanceRolePolicies:
    Type: AWS::IAM::Policy
    Properties:
      PolicyName: "InstanceRole"
      PolicyDocument: 
        Version: "2012-10-17"
        Statement:
          - 
           Effect: "Allow"
           Action: 
              - "autoscaling:Describe"
              - "cloudformation:Describe*"
              - "cloudformation:GetTemplate"
              - "s3:Get*"
              - "s3:List*"              
           Resource: "*"
      Roles: 
        - Ref: "InstanceRole"       
  WSASG:
    Type: AWS::AutoScaling::AutoScalingGroup
    Properties: 
      LaunchConfigurationName: 
        Ref: "WSLaunchConfiguration"
      VPCZoneIdentifier: 
        - Ref : "PublicSubnet1"
          Ref : "PublicSubnet2"
      MinSize: '0'
      MaxSize: '4'
      DesiredCapacity:
        Ref : "InstanceCount"
      LoadBalancerNames: 
        - Ref : "ELB"
      HealthCheckType: "ELB"
      HealthCheckGracePeriod: 600
      Tags: 
        - Key : "Name"
          Value: "CodeDeployDemo"
          PropagateAtLaunch: true 
    CreationPolicy: 
      ResourceSignal: 
        Count: 
          Ref: "InstanceCount" 
        Timeout: "PT15M"
    UpdatePolicy:
      AutoScalingRollingUpdate:
        MinInstancesInService: '1'
        MaxBatchSize: '1'
  WSLaunchConfiguration: 
    Type: AWS::AutoScaling::LaunchConfiguration
    Properties:
      ImageId: !FindInMap [AWSRegionArch2AMI, !Ref "AWS::Region","AMI"]
      InstanceType:
        Ref: CodedeployInstanceType
      SecurityGroups: 
        - Ref: "WSSG"
      UserData: 
        Fn::Base64: !Sub |
           #!/bin/bash -xe
           sudo yum update -y
           sudo yum install -y ruby
           sudo yum install -y wget
           sudo wget https://aws-codedeploy-${AWS::Region}.s3.${AWS::Region}.amazonaws.com/latest/install
           sudo chmod +x ./install
           sudo ./install auto
           # Start cfn-init
           /opt/aws/bin/cfn-init -s ${AWS::StackId} -r WSLaunchConfiguration --region ${AWS::Region}
           # Signal the status from cfn-init
           /opt/aws/bin/cfn-signal -e $? --stack ${AWS::StackName} --resource WSASG --region ${AWS::Region} 
      KeyName: 
        Ref: "SSHKey"
      IamInstanceProfile:
        Ref: "CodeDeployInstanceProfile"
      AssociatePublicIpAddress: true
    Metadata: 
      AWS::CloudFormation::Init:
          services:
            sysvinit:
              codedeploy-agent:
                enabled: true
                ensureRunning: true

由于我是AWS新手,因此在这里我几乎不需要帮助

2 个答案:

答案 0 :(得分:0)

检查S3Location资源下的DemoFleet

Bucket: Fn::Join:["",["aws-codedeploy-" !Ref["AWS::Region"]]]的格式不正确。

尝试以下

DemoFleet:
  Type: AWS::CodeDeploy::DeploymentGroup
  Properties:  
    ApplicationName: !Ref DemoApplication
    AutoScalingGroups: 
      - !Ref WSASG
    Deployment: 
      Description: "Initial Deployment"
      Revision: 
        RevisionType: S3
        S3Location: 
          Bucket: !Sub 'aws-codedeploy-${AWS::Region}'
          BundleType: "zip"
          Key: "samples/latest/SampleApp_Linux.zip"
    DeploymentConfigName: "CodeDeployDefault.OneAtATime"
    ServiceRoleArn: !GetAtt CodeDeployTrustRole.Arn

答案 1 :(得分:0)

如果堆栈自动回滚,则在创建堆栈时禁用回滚[1],然后在堆栈失败后,转到CodeDeploy控制台并在“ Deployments”下查找部署ID。部署详细信息将为您提供失败原因。

[1] https://aws.amazon.com/premiumsupport/knowledge-center/cloudformation-prevent-rollback-failure/