2017-02-16 5 views
2

私のプロジェクトにAWS CodeBuildを使用しようとしています。私のビルドはaws/codebuild/docker:1.12.1イメージで実行されています。これは、環境変数のAWS Docker SampleAWS CodeBuildコマンドが実行されないのはなぜですか?

version: 0.1 

phases: 
    pre_build: 
    commands: 
     - echo Logging in to Amazon ECR... 
     - $(aws ecr get-login --region $AWS_DEFAULT_REGION) 
    build: 
    commands: 
     - echo Build started on `date` 
     - echo Building the Docker image...   
     - docker build -t $IMAGE_REPO_NAME . 
    post-build: 
    commands: 
     - echo Build completed on `date` 
     - docker tag $IMAGE_REPO_NAME:$IMAGE_TAG $AWS_ACCOUNT_ID.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com/$IMAGE_REPO_NAME:$IMAGE_TAG 
     - docker push $AWS_ACCOUNT_ID.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com/$IMAGE_REPO_NAME:$IMAGE_TAG 

すべてから撮影された私のbuildspec.yml、ビルド構成に定義されています。しかし、これは私のCodeBuildのログ出力です:

[Container] 2017/02/16 22:04:24 Waiting for agent 
[Container] 2017/02/16 22:04:33 Phase is DOWNLOAD_SOURCE 
[Container] 2017/02/16 22:04:34 Source is located at /tmp/src733484785/src 
[Container] 2017/02/16 22:04:34 YAML location is /tmp/src733484785/src/buildspec.yml 
[Container] 2017/02/16 22:04:34 Registering with agent 
[Container] 2017/02/16 22:04:34 Phases found in YAML: 3 
[Container] 2017/02/16 22:04:34 PRE_BUILD: 2 commands 
[Container] 2017/02/16 22:04:34 BUILD: 3 commands 
[Container] 2017/02/16 22:04:34 POST-BUILD: 3 commands 
[Container] 2017/02/16 22:04:34 Phase complete: DOWNLOAD_SOURCE Success: true 
[Container] 2017/02/16 22:04:34 Phase context status code: Message: 
[Container] 2017/02/16 22:04:34 Processing plaintext environment variables 
[Container] 2017/02/16 22:04:34 Processing build-level environment variables 
[Container] 2017/02/16 22:57:53 {"AWS_DEFAULT_REGION":"<censored>","AWS_ACCOUNT_ID":"<censored>","IMAGE_TAG":"<censored>","IMAGE_REPO_NAME":"<censored>"} 
[Container] 2017/02/16 22:57:53 AWS_DEFAULT_REGION = <censored> 
[Container] 2017/02/16 22:57:53 AWS_ACCOUNT_ID = <censored> 
[Container] 2017/02/16 22:57:53 IMAGE_TAG = <censored> 
[Container] 2017/02/16 22:57:53 IMAGE_REPO_NAME = <censored> 
[Container] 2017/02/16 22:04:34 Processing builtin environment variables 
[Container] 2017/02/16 22:04:34 Moving to directory /tmp/src733484785/src 
[Container] 2017/02/16 22:04:34 Preparing to copy artifacts 
[Container] 2017/02/16 22:04:34 No artifact files specified 

CodeBuildは私のコマンドを見ますが、実行しません!ビルドには成功とマークされます。誰も私がここで間違っていることを知っていますか?

更新:post-buildpost_buildに変更する必要がありました。ビルドではmavenイメージを取得してjarファイルを作成し、ドッカーがイメージを構築します。この方法では、私のjarにはソースコードが含まれておらず、イメージにはmavenとjdkが含まれていません。

version: 0.1 

phases: 
    pre_build: 
    commands: 
     - echo Logging in to Amazon ECR... 
     - $(aws ecr get-login --region $AWS_DEFAULT_REGION) 
     - echo Pulling maven image... 
     - docker pull maven:3.3-jdk-8 
    build: 
    commands: 
     - echo Build started on `date` 
     - echo Building jar... 
     - docker run -i --rm -w /opt/maven -v $PWD:/opt/maven -v $HOME/.m2:/root/.m2 maven:3.3-jdk-8 mvn clean install 
     - echo Building Docker Image... 
     - docker build -t $IMAGE_REPO_NAME . 
     - docker tag $IMAGE_REPO_NAME:$IMAGE_TAG $AWS_ACCOUNT_ID.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com/$IMAGE_REPO_NAME:$IMAGE_TAG 
    post_build: 
    commands: 
     - echo Build completed on `date` 
     - echo Pushing Docker image... 
     - docker push $AWS_ACCOUNT_ID.dkr.ecr.$AWS_DEFAULT_REGION.amazonaws.com/$IMAGE_REPO_NAME:$IMAGE_TAG 
+0

私は何をしたのか分かりませんが、それは働き始めました。誰かがフレークさの原因を知っていますか? – zalpha314

+0

あなたはこれがうまくいく理由を理解しましたか?私は同じ問題があると思っています – cdimitroulas

+0

@cdimitroulas、いいえ、私はそれがインデントとリストのスペーシングと関係していたと思います。 YAMLは、すべてのことについて非常に厄介です。 – zalpha314

答えて

7

post-buildBuild Specification Referenceあたりとしてpost_build次のようになります。これは私の作業buildspec.ymlです。

+0

はい、私はそれが機能するように変更したと思います。答えをありがとう。 – zalpha314

関連する問題