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

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

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

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Azure

Azureは、マイクロソフトのクラウド プラットフォームで、旧称は Windows Azureです。PaaSとIaaSを組み合わせることで、 コンピューティング・ストレージ・データ・ネットワーキング・アプリケーションなど多くの機能を持ちます。

Q&A

解決済

1回答

4060閲覧

Laravel + Dokcer + Azure App Service でWebサイトを構築したいです。

kochataro

総合スコア14

Docker

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Azure

Azureは、マイクロソフトのクラウド プラットフォームで、旧称は Windows Azureです。PaaSとIaaSを組み合わせることで、 コンピューティング・ストレージ・データ・ネットワーキング・アプリケーションなど多くの機能を持ちます。

0グッド

0クリップ

投稿2017/12/12 13:15

###前提・実現したいこと
・Laravel + Dokcer + Azure App Service でWebサイトを構築しようと考えています。
・次のソースがAzure App Server上で動くようにしたいです。
https://github.com/Labs64/laravel-boilerplate
・ローカルではREADME.mdにしたがって動作確認しています。
https://github.com/Labs64/laravel-boilerplate#docker
・Repogitoryは、Docker Hubです。
●Microsoft のチュートリアルでカスタムDocker + Azure App Service は確認できました。
そのサンプルと異なる点は次のとおりです。
https://docs.microsoft.com/ja-jp/azure/app-service/containers/tutorial-custom-docker-image
・Dockerfileは直下ではなく、一階層下に作成している
・laravelの方はdocker-compose.ymlにコマンドを記載し、docker-compose.ymlの中からDockerfileを呼び出している
・local環境では、「docker-compose up」の後に「docker exec」として起動させている

###発生している問題
1.Containerの起動に失敗しています。
2.SSH接続ができません。

####1.Containerの起動に失敗
App Serviceの診断ログからContainerの起動に失敗していることを確認しています。

<中略> INFO - Starting container for site INFO - docker run -d -p 19186:80 --name mydockerimagelaravel_0 -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=mydockerimagelaravel -e WEBSITE_AUTH_ENABLED=False -e PORT=80 -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_INSTANCE_ID=bb373487faa397d31d2497128207a7ad57d45bb01e3a2ffa4c81f0cd158e28dc gitlab/gitlab-runner:latest INFO - Logging is not enabled for this container. Please use https://aka.ms/linux-diagnostics to enable logging to see container logs here. INFO - Container logs Starting multi-runner from /etc/gitlab-runner/config.toml ... builds=0 Running in system-mode.   Configuration loaded  builds=0 Metrics server disabled  ERROR - Container mydockerimagelaravel_0 for site mydockerimagelaravel did not start within expected time limit. Elapsed time = 230.0459745 sec INFO - Issuing docker pull: imagename =gitlab/gitlab-runner:latest INFO - docker pull returned STDOUT>> latest: Pulling from gitlab/gitlab-runner Digest: sha256:744a14efe93ae6a9ee208990416cc217229d9922a21fa2bfb6605ac834d3e89b Status: Image is up to date for 10.0.5.10:13210/gitlab/gitlab-runner:latest INFO - Starting container for site INFO - docker run -d -p 13018:80 --name mydockerimagelaravel_0 -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=mydockerimagelaravel -e WEBSITE_AUTH_ENABLED=False -e PORT=80 -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_INSTANCE_ID=bb373487faa397d31d2497128207a7ad57d45bb01e3a2ffa4c81f0cd158e28dc -e HTTP_LOGGING_ENABLED=1 gitlab/gitlab-runner:latest INFO - Container logs Starting multi-runner from /etc/gitlab-runner/config.toml ... builds=0 Running in system-mode.   Configuration loaded  builds=0 Metrics server disabled  ERROR - Container mydockerimagelaravel_0 for site mydockerimagelaravel did not start within expected time limit. Elapsed time = 230.1907204 sec INFO - Issuing docker pull: imagename =gitlab/gitlab-runner:latest INFO - docker pull returned STDOUT>> latest: Pulling from gitlab/gitlab-runner Digest: sha256:744a14efe93ae6a9ee208990416cc217229d9922a21fa2bfb6605ac834d3e89b Status: Image is up to date for 10.0.5.10:13210/gitlab/gitlab-runner:latest INFO - Starting container for site INFO - docker run -d -p 44212:80 --name mydockerimagelaravel_0 -e WEBSITES_ENABLE_APP_SERVICE_STORAGE=false -e WEBSITE_SITE_NAME=mydockerimagelaravel -e WEBSITE_AUTH_ENABLED=False -e PORT=80 -e WEBSITE_ROLE_INSTANCE_ID=0 -e WEBSITE_INSTANCE_ID=bb373487faa397d31d2497128207a7ad57d45bb01e3a2ffa4c81f0cd158e28dc -e HTTP_LOGGING_ENABLED=1 gitlab/gitlab-runner:latest ERROR - Container mydockerimagelaravel_0 for site mydockerimagelaravel did not start within expected time limit. Elapsed time = 230.0936177 sec

#####2. SSH接続ができない
Azureコンソールから対象のApp Serviceの「SSH」をしようとすると次のエラーで接続できません。
エラー内容「SSH CONNECTION CLOSE - Error: connect EHOSTUNREACH 172.20.0.2:2222 CREDENTIALS」
チュートリアルとのサンプルとSSHサポートページを参考にDockerfileには下記のように記載しています。
docker build は正常に完了しています。

# SSH Server support ENV SSH_PASSWD "root:Docker!" RUN yum -y update \ && yum install -y dialog \ && yum -y update \     && yum install -y openssh-server \     && echo "$SSH_PASSWD" | chpasswd COPY sshd_config /etc/ssh/ COPY init_container.sh /usr/local/bin/ RUN chmod u+x /usr/local/bin/init_container.sh EXPOSE 8000 22 9000 ENTRYPOINT ["init_container.sh"]

###詰まっている箇所
今回の構成で次の5点について教えていただきたいです。

  1. docker image作成のコマンドが通常の「docker build」ではなく「docekr-compose」のオプションなど、別の方法で作成する必要がありますか?
  2. docker hubへのプッシュも方法が異なるでしょうか?(またはAzure Container Registry)
  3. そもそもApp Serviceで「docker-compose up」使用できますか?
  4. composerの設定も全てdockerfileに書き、フォルダ直下にdockerfileを作成できるでしょうか?
  5. MSサンプルは、コードをDockerfileでADDを使っていて、laravelサンプルはdocker-compose.ymlでvolumesを使っているのですが、これもサンプルに合わせてコードをADDする必要がありますか?

よろしくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

App Service on Linux は、シングルコンテナー環境が前提のサービスなので、マルチコンテナー環境のイメージでは使えないそうです。。。。

投稿2017/12/13 06:09

kochataro

総合スコア14

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問