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

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

ただいまの
回答率

89.71%

DockerでMySQLに接続できません

解決済

回答 3

投稿

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

前提・実現したいこと

『はじめてのPHPプロフェッショナル開発 PHP7対応』という書籍で勉強をしています。

dockerを使用しCakePHPでの開発を進めたいのですが、MySQLに接続ができません。

環境:Windows10
使用ツール:Docker for Windows
(本がMacOS前提で書かれているのでコマンドが違っているのかもしれません。)

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

実行したコマンド 
mysql -u root -h 127.0.0.1 -P 13306 -p
次に実行してみたコマンド
mysql -u root -h 127.0.0.1 -P 13306 -p secret
エラーメッセージ
mysql : 用語 'mysql' は、コマンドレット、関数、スクリプト ファイル、
または操作可能なプログラムの名前として認識されません。
名前が正しく記述されていることを確認し、
パスが含まれている場合はそのパスが正しいことを確認してから、再試行してください。
発生場所 行:1 文字:1
+ mysql -u root -h 127.0.0.1 -P 13306 -p secret
+ ~~~~~
    + CategoryInfo          : ObjectNotFound: (mysql:String) [], CommandNotFoundException
    + FullyQualifiedErrorId : CommandNotFoundException

該当のソースコード

docker-compose.yml

version: '3'
services:
  web: #サービス名の設定「web」
    container_name: php-book-app-web #コンテナ名の設定
    build: #ビルド時の設定
      context: .
      dockerfile: ./Docker/php/Dockerfile #./Docker/php/Dockerfileを使ってビルドする指定
    volumes: #ディレクトリのマウントの設定
      - .:/var/www/html:cached
    environment:
      - API_DEFAULT_LOCALE=ja_JP
      - API_DEFAULT_TIMEZONE=Asia/Tokyo
    command: bash -c "sh docker-init-setup.sh && apache2-foreground" #apache2-foregroundを実行する処理
    ports: #ポートフォワーディングの設定
      - "5000:80"
  db: #サービス名の設定「db」
    container_name: php-book-app-db #コンテナ名
    build: #ビルド時の設定
      context: .
      dockerfile: ./Docker/mysql/Dockerfile
    environment: #rootユーザーのパスワード設定
      - MYSQL_ROOT_PASSWORD=secret
    ports: #ポートフォワーディングの設定
      - "13306:3306" #3306はMysqlのデフォルトポート番号


Dockerfile

FROM mysql:5.7
# 文字化け防止
ADD ./Docker/mysql/conf.d/my.cnf /etc/mysql/conf.d/my.cnf


my.cnf

[mysqld]
character-set-server=utf8mb4

[mysql]
default-character-set=utf8mb4

[client]
default-character-set=utf8mb4

補足

WindowsPowerShellを使っており、docker-compose up -d dbでMySQLは起動しました。
そのあとmysql -u root -h 127.0.0.1 -P 13306 -pで接続しようとしたのですがエラーメッセージが表示されます。
書籍がMac用に書かれていてWindowsとコマンド内容が違うせいかもしれません。

よろしくお願いします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • t_obara

    2019/03/19 19:27

    すでに回答されているので、コメントです。
    dockerインスタンスの中にあるmysqlをホスト側で呼び出そうとしても呼び出せません。呼べてしまったら、なんのためにdockerで環境を分離しているのかわかりませんよね。

    キャンセル

  • HarukaNishiyama

    2019/03/20 11:43 編集

    様々なご意見ありがとうございました。
    mysql以前に放置していた不具合もあるため、もう一度最初からテキストを進めます。
    またたくさんの不具合が出るかと思いますので、懲りずにご意見をくださるとうれしいです・・・。

    キャンセル

回答 3

check解決した方法

0

各々の設定を見直し、自己解決しました。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

あてずっぽう

  • 環境変数でパスが通っていない
  • mysqlクライアントがインストールされていない
  • 実行権限がない

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/03/20 10:18

    ありがとうございます。
    mysaqlコマンドが見つからないというエラーが出ているので mysqlをインストールできていないのかと思います。
    とはいえインストールしても同様のエラーが出てしまいました・・・

    キャンセル

  • 2019/03/20 10:34

    そもそもmysqlはコマンドラインでアクセスしても大したことはできません
    なんらかのGUIツールを導入することをお勧めします

    キャンセル

  • 2019/03/20 11:48

    GUIというとphpmyadminなどでしょうか・・・?

    キャンセル

0

書店で拝見しました。
その前の段落に、「コマンドが使えなかったらサポートリポジトリを参考にインストールするよう」指示がありませんか?

ここみてchocolateyでインストールしてみてください。

ちな、yambejp様の2つ目の・に該当

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/03/20 10:16

    ありがとうございます。
    サイトを見てchoco install mysqlを実行しました。
    それでも同じようなエラーが出てしまいます・・・

    キャンセル

  • 2019/03/20 10:29

    「同じような」は同じなんですか違うのですか?
    同じならインストールができていません。
    違うなら違うメッセージ次第です。

    キャンセル

  • 2019/03/20 11:50

    まったく同じメッセージですので、インストールができていないのだと思います。
    とりあえずテキストを最初からやり直してみることにしました。

    また質問に答えていただけると嬉しいです・・・ありがとうございました。

    キャンセル

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

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