質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

2回答

4426閲覧

CircleCI + Ruby on Rails + ECS の自動デプロイがうまくいかず困っています

kaoru6strings

総合スコア15

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Docker

Dockerは、Docker社が開発したオープンソースのコンテナー管理ソフトウェアの1つです

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2019/04/03 11:07

編集2019/04/05 00:33

概要

この度Ruby on Railsで作成されたアプリをCircleCIを用いてECSへ自動デプロイしようと挑戦しています。下記2点がどうしてものりこえられず困っています。ご助言、ご指摘いただけると助かります。

環境

  • CircleCI 2.0
  • ECS on Fargate

困っていること

1. Ruby on RailsをECSへデプロイする際db:migrateをかけたいのですが以下のコードでうまくいきません

.circleci/config.ymlの該当箇所のコード

- run: name: "DB Migrate" command: | aws ecs run-task \ --region REGION \ --cluster my-rails-cluster \ --task-definition my-rails-task \ --overrides file://docker/run_task_db_migrate.json working_directory: web

file://docker/run_task_db_migrate.jsonの中身

{ "containerOverrides": [ { "name": "web", "command": ["bundle", "exec", "rails", "db:migrate"] } ] }

CircleCIが出力したエラー文

An error occurred (InvalidParameterException) when calling the RunTask operation: Network Configuration must be provided when networkMode 'awsvpc' is specified. Exited with code 255

2. ecs-deployを用いたECSへの更新がうまくいきません

.circleci/config.ymlの該当箇所のコード

- run: name: "Service deploy" command: | ecs-deploy -c my-rails-cluster -n my-rails-service -i my-rails-ecr-repo

CircleCIが出力したエラー文

Using image name: my-rails-ecr-repo Current task definition: arn:aws:ecs:REGION:MYID:task-definition/my-rails-ecr-task:3 New task definition: arn:aws:ecs:REGION:MYID:task-definition/my-rails-ecr-task:4 ERROR: New task definition not running within 90 seconds Exited with code 1

足りない情報などもしありましたら教えていただけると助かります。
よろしくお願いします!m(_ _)m

原因と解決方法(2019/04/05)

おかげさまでひとまず解決することができましたので原因と解決方法を記しておきます

1. Ruby on RailsをECSへデプロイする際db:migrateをかけたいのですが以下のコードでうまくいきません

  1. Railsアプリで使用するRDSのセキュリティグループの設定が間違っていた
  2. aws ecs run-taskを実行する際に--network-configuration--launch-type FARGATEオプションが足りなかった(Fargate使用時は必須みたいです)正しいコマンドは下記です。
- run: name: "DB Migrate" command: | aws ecs run-task \ --region REGION \ --cluster my-rails-cluster \ --task-definition my-rails-task \ --overrides file://docker/run_task_db_migrate.json --network-configuration "awsvpcConfiguration={subnets=[subnet-xxxxxx,subnet-xxxxxx],securityGroups=[sg-xxxxxxx],assignPublicIp=DISABLED}" working_directory: web

2. ecs-deployを用いたECSへの更新がうまくいきません

こちらに関してはデプロイはうまくできているが、タスクが正常に動作しているかどうかのチェックの部分でecs-deploy側でタイムアウトしているのが原因でした。今回は取り急ぎデプロイ時のコマンドに--skip-deployments-checkを足したところ正常に動作しました

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

2 については、単純に Task Definition の設定が誤っている可能性が高いです。
発生しているエラー内容のコードは下記行です。run-task 実行時にコケているかもしれません。
https://github.com/silinternational/ecs-deploy/blob/develop/ecs-deploy#L426

Task Definition の設定内容が分からないのでなんとも言えませんが、実際に AWS マネージメントコンソールもしくは、AWS CLI にて Task を実行してみてください。その際に詳細なエラー内容が出力されます。
デバッグ時に有効です。

投稿2019/04/03 13:36

enkw_

総合スコア54

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

1 について、 Task Definition の Network Mode は awsvpc かと思います。であれば、 aws ecs run-task 実行の際に --network-configuration Option を指定する必要があります。
私の環境でも、 --network-configuration Option を指定せずに、同様のエラーが発生することを確認しました。

$ aws ecs run-task --cluster enokawa --task-definition nginx An error occurred (InvalidParameterException) when calling the RunTask operation: Network Configuration must be provided when networkMode 'awsvpc' is specified.

--network-configuration Option を追加して aws ecs run-task を実行した結果が下記です。問題なく成功しています。

$ aws ecs run-task --cluster enokawa --task-definition nginx \ --network-configuration "awsvpcConfiguration={subnets=[subnet-xxxxxx,subnet-xxxxxx],securityGroups=[sg-xxxxxxx],assignPublicIp=DISABLED}" { "tasks": [ { "taskArn": "arn:aws:ecs:ap-northeast-1:XXXXXXXXXXXXXX:task/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx", . . .

AWS CLI のリファレンスにも記載されているので確認してみましょう。
https://docs.aws.amazon.com/cli/latest/reference/ecs/run-task.html

投稿2019/04/03 11:55

編集2019/04/03 11:59
enkw_

総合スコア54

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kaoru6strings

2019/04/03 14:30

2点回答ありがとうございました!1番目に関しては、今回Fargateを利用していたため、ご回答いただいた内容に、 `--launch-type FARGATE` を加えたら実行できました!ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問