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

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

ただいまの
回答率

90.84%

  • Laravel 5

    1617questions

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

  • Docker

    578questions

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

  • Azure

    193questions

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

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

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 297

kochataro

score 7

前提・実現したいこと

・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する必要がありますか?

よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

check解決した方法

0

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

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.84%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • Laravel 5

    1617questions

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

  • Docker

    578questions

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

  • Azure

    193questions

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