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

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

ただいまの
回答率

90.51%

  • Docker

    1047questions

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

  • docker-compose

    240questions

dockerでmysqlに接続するにはどうすればいいか

解決済

回答 2

投稿

  • 評価
  • クリップ 2
  • VIEW 1,930

taka96

score 4

 前提・実現したいこと

docker-composeを利用してphp、nginx、mysqlの環境を作りたい

ここに質問の内容を詳しく書いてください。
現状docker-composeを利用してnginxとPHPを利用できる環境を作成するところまではできています。
そこからmysqlに接続しようと調べましたがやり方がわからずに一週間くらい止まっています。
どなたか助けてください。

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

docker-compose up -dでnginxとphpとmysqlが動いていることは確認できています。
イメージ説明
mysqlにexecで接続後テーブルを作成してphp側で接続をできるかテストしたところうまくいかないです。
設定を変えてみたりして以下のエラーが出てから進んでいないです。

1.
SQLSTATE[HY000] [2002] Connection refused
2.
MySQL server has gone away

 該当のソースコード

docker-compose.yml

version: '2'
services:
  sqlbox:
    container_name: sqlbox
    image: busybox
    volumes:
      - ./data/mysql:/var/lib/mysql/data
    networks:
      - dev-net

  wwwbox:
    container_name: wwwbox
    image: busybox
    volumes:
      - ./data/www:/var/www/html
    networks:
      - dev-net

  dev-nginx: 
    container_name: dev-nginx
    build: ./nginx
    ports: 
      - "80:80"
    links: 
      - dev-php
    volumes:
      - ./nginx/server.conf:/etc/nginx/conf.d/server.conf
    volumes_from:
      - wwwbox
    networks:
      - dev-net

  dev-php: 
    container_name: dev-php
    build: ./php7
    links: 
      - dev-mysql
    volumes:
      - ./php7/php.ini:/usr/local/etc/php/php.ini
    volumes_from:
      - wwwbox
    networks:
      - dev-net
    depends_on:
      - "dev-mysql"

  dev-mysql:
    container_name: dev-mysql
    image: mysql:5.6
    volumes:
      - ./mysql:/etc/mysql/conf.d
    ports: 
      - "5432:5432"
    volumes_from:
      - sqlbox
    networks:
      - dev-net
    environment:
      - "MYSQL_ROOT_USER=roottest"
      - "MYSQL_ROOT_PASSWORD=rootpass"
      - "MYSQL_ALLOW_EMPTY_PASSWORD=no"
      - "MYSQL_DATABASE=test"
      - "MYSQL_USER=test"
      - "MYSQL_PASSWORD=passpass"
      - "TZ=Asia/Tokyo"

networks:
  dev-net:
    driver: bridge


index.php

<?php
    $hostname = "192.168.99.100";
    $username = "test";
    $password = "passpass";
    $dbname = "test";
    $char = "utf8";
    $port = "5432";

    try{
        //DBを選択してコネクト
        $db_perm = array(
                PDO::ATTR_EMULATE_PREPARES => false,
                PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
            );
        $link = new PDO('mysql:host='.$hostname.'; port='.$port.'; dbname='.$dbname.'; charset='.$char , $username, $password, $db_perm);

        //SELECT文を発行
        $result = $link->query('select ID,Name from member_tb where Name = "Mako Ishino"'); 

        //ヒット数を表示
        $duplicate_num =  $result->rowCount();
        echo $duplicate_num ." 件該当しました。<br>\n";

        //接続をクローズ
        $result = null;
        $link = null;

    } catch( PDOException $e) {
        $db_error = $e->getMessage();
        error_log($db_error);
        print 'DBエラー: ' . $db_error  .'<br>' ;
        die($db_error);
    }

 試したこと

index.phpのhostやportの設定の変更等

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

centos 7
php 7.2
mysql 5.6
docker 18.01.0-ce
windows10 home

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

PHPのここ直しましょう。

$hostname = "192.168.99.100";

まずはPHPのコンテナにdocker-composeを使って入り込んで見ましょう。
dockerのdependentやlinkはぶっちゃけ、/etc/hostsに書き込んで終わりです。
従って、/etc/hostsファイルさえ確認すれば何処に接続すべきかが分かります。

$ docker-compose exec dev-php bash

$ cat /etc/hosts

そうすれば、dev-phpというホストのIPアドレスが分かります。
これはdocker runでコンテナが作られた瞬間解決されることなので、
PHPの$hostname変数の値はdev-phpという文字列でよい事がわかります。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/03/06 23:17 編集

    回答ありがとうございます。

    $hostname = "192.168.99.100";

    上記のPHPに変更してみましたが、下記のようなエラーが出てしまい、繋がらない状態になっています。
    エラー内容:「SQLSTATE[HY000] [2006] MySQL server has gone away」

    hostの確認もしてみました。IP contaner IDの順で記載されているのも把握できました。
    すみません、そこからの接続がわからないです・・・

    172.20.0.2 c8ef6962eac6

    キャンセル

  • 2018/03/07 01:32

    上記解決しました。後日解決方法を更新します

    キャンセル

+1

$hostname = "192.168.99.100";

回答にもありましたが、上記のように変更しても繋がらなかったので、「docker exec」コマンドでmysqlのコンテナに接続して/etc/hostsに書いてあるIPに変更すれば接続できました。

これが正しいやり方なのかは不明。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

  • Docker

    1047questions

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

  • docker-compose

    240questions