###前提・実現したいこと
・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 ...[0;m builds[0;m=0 Running in system-mode. [0;m [0;m Configuration loaded [0;m builds[0;m=0 Metrics server disabled [0;m 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 ...[0;m builds[0;m=0 Running in system-mode. [0;m [0;m Configuration loaded [0;m builds[0;m=0 Metrics server disabled [0;m 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点について教えていただきたいです。
- docker image作成のコマンドが通常の「docker build」ではなく「docekr-compose」のオプションなど、別の方法で作成する必要がありますか?
- docker hubへのプッシュも方法が異なるでしょうか?(またはAzure Container Registry)
- そもそもApp Serviceで「docker-compose up」使用できますか?
- composerの設定も全てdockerfileに書き、フォルダ直下にdockerfileを作成できるでしょうか?
- MSサンプルは、コードをDockerfileでADDを使っていて、laravelサンプルはdocker-compose.ymlでvolumesを使っているのですが、これもサンプルに合わせてコードをADDする必要がありますか?
よろしくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。