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

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

ただいまの
回答率

89.55%

docker-composeでコンテナが起動しない

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 7,627

saken649

score 58

前提・実現したいこと

お世話になっております。
Dockerを用いて、LAMP環境を作成しようとしております。
アプリ用コンテナ(Apache+PHP)とDB用コンテナの2つのコンテナを使用して構築したいです。

※AWSのEC2でAmazonLinuxを使用した際、というのを想定した環境を作りたいです。
ゆくゆくはScality S3ServerもくっつけてS3を想定した環境も使えるようにしたいですが、一旦まずはちゃんと動くLAMP環境を構築したく。

発生している問題・エラーメッセージ

  • docker-composeを実行した際、アプリ用のコンテナが起動しない
    => Exited(0)となり、起動しない
    => DB用のコンテナは立ち上がっている
$ docker-compose up -d
Creating gupsearch_db_1  ... done
Creating gupsearch_db_1  ... 
Creating gupsearch_app_1 ... done
$ 
$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
7c90c79911f2        mysql:latest        "docker-entrypoint.s…"   3 seconds ago       Up 5 seconds        3306/tcp            gupsearch_db_1
$ 
$ docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                      PORTS               NAMES
ef1e2e449b32        gupsearch_app       "/bin/sh -c 'service…"   14 seconds ago      Exited (0) 15 seconds ago                       gupsearch_app_1
7c90c79911f2        mysql:latest        "docker-entrypoint.s…"   14 seconds ago      Up 16 seconds               3306/tcp            gupsearch_db_1
$ 
$ docker-compose logs | grep app_1
Attaching to gupsearch_app_1, gupsearch_db_1
app_1  | Starting httpd: httpd: Could not reliably determine the server's fully qualified domain name, using 172.18.0.3 for ServerName
app_1  |                                                   [  OK  ]
$ 

docker-compose logsの結果、特にエラーが出ているわけでもなさそうです。。

該当のソースコード

  • docker-compose.yml
version: '2'
services:
  db:
    image: "mysql:latest"
    environment:
      MYSQL_ROOT_PASSWORD: root1234
      MYSQL_DATABASE: test_db
      MYSQL_USER: app
      MYSQL_PASSWORD: app1234
  app:
    build: ./docker/app/
    ports:
      - "80:80"
    expose:
      - "9000"
    links:
      - db
    volumes:
      - ./src:/var/www/html
    stdin_open: true
    tty: true

※9000番ポートはXDebug用に開けています。

  • ./docker/app/Dockerfile
FROM amazonlinux:latest
RUN rpm -Uvh https://mirror.webtatic.com/yum/el6/latest.rpm \
    && yum -y update \
    && yum -y install httpd \
        mod_php71w \
        php71w-opcache \
        php71w-cli \
        php71w-common \
        php71w-devel \
        php71w-mbstring \
        php71w-mysql \
        php71w-pdo \
        php71w-pear \
        php71w-pecl-redis \
        php71w-pecl-xdebug \
        php71w-xml \
    && chkconfig httpd on
ENTRYPOINT service httpd start

試したこと

補足情報(言語/FW/ツール等のバージョンなど)

  • 実行時はdocker-compose build => docker-compose up -dとしています。
  • docker-composeせず、地道にdocker build => docker run -itとした時は、問題無くApacheのテスト画面が表示されました。

実行環境

  • macOS 10.13.2 High Sierra
  • Docker CE For Mac
$ docker -v
Docker version 17.12.0-ce, build c97c6d6
  • VirtualBoxは入っていません。
    (特に入れるよう指示もされていませんし、Requirementsにも記載が無かったかと。)

今まで、WindowsのHyper-Vで動くDocker For Windowsでやっていて、こんなことは一度も起きたことがありませんでした。
stdin_openttyオプションは今回初めて使用したくらいです。

Macに移ってきて、さっそく躓いているので、Dockerに詳しい方の助言を頂けますと幸いです。
どうぞよろしくお願い致します。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

check解決した方法

+1

自己解決しました。
結論から言うと、Dockerfileでchkconfigしたりservice httpd startしてるのがマズかったようで、それ無くしたら問題なく動きました。
じゃあdocker-compose upした時にApacheも同時に立ち上げるには。。?と思ったのですが、それはまた別の問題なので、一旦クローズとします。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

Dockerfileを使用しているのであれば、docker-compose up -d --buildとする必要があるのではないでしょうか?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/01/22 11:36

    kenny_sayama様

    コメント有難うございます。
    もちろんその認識でおりますので、

    > 実行時はdocker-compose build => docker-compose up -dとしています。

    とした次第です。
    (buildしてからup -d)

    up時のオプションにビルドを指定するのと挙動が違ったら嫌なので、一度それは試してみたいと思います。

    キャンセル

  • 2018/01/23 22:24

    kenny_sayama様

    ご指南頂いた方法でも挙動は変わりませんでした。
    別のところが問題で自己解決しました。
    コメント頂き有難うございました。

    キャンセル

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

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