MySQLを開発に使っている時に、
今回はDockerを使って5.
デモンストレーション環境について
今回はDockerでMySQLの環境を複数用意して見るために、
data:image/s3,"s3://crabby-images/cbb11/cbb1196a6798e8003acd9f17b8fb370a9971080f" alt="図1 kitematic公式トップ 図1 kitematic公式トップ"
KitematicはDockerのシンプルなオープンソースソフトウェアで、
Kitematic(Docker Toolbox)のインストール
Kitematicは現在はDockerのToolboxとして提供されています。Dockerの公式ページからOSにあったものをDownloadします。筆者の環境はMacなのでDownload(Mac)からダウンロードしました。バージョンはこの記事を書いている時の最新版1.
data:image/s3,"s3://crabby-images/98d40/98d409c695a1e863deed3be54132ff7e8e5d0101" alt="図2 Kitematicダウンロード画面 図2 Kitematicダウンロード画面"
インストーラを起動すると次の画面が表示されます。
data:image/s3,"s3://crabby-images/aebd6/aebd6e5202b82b7f95e87411cd1f883f84e7b018" alt="図3 インストール画面1 図3 インストール画面1"
続けるをどんどん押していきます。一部パスワードを求められますので、
data:image/s3,"s3://crabby-images/750b4/750b4d6e47b44e03183a235d67648b75ec9ef01d" alt="図4 パスワード入力画面 図4 パスワード入力画面"
終了画面のひとつ前の画面で、
data:image/s3,"s3://crabby-images/2e33c/2e33c7bb8cbe59db192b6ea0e549509d5602fc4f" alt="図5 QuickStart画面 図5 QuickStart画面"
続けるを押してインストールが完了します。続けて初期設定に移ります。
data:image/s3,"s3://crabby-images/ac002/ac002b85a00a5ec65d0b4f45e18a0c16e4ab30da" alt="図6 初期設定画面 図6 初期設定画面"
DockerHubアカウントをお持ちの場合は入力してください。DockerHubはDockerコンテナを公開するためのWebサービスでDockerレジストリを構築することができるので便利ですが、
data:image/s3,"s3://crabby-images/e7a0f/e7a0f6ef1be6b69b3235f1c9d53436feeeecb863" alt="図7 起動画面 図7 起動画面"
さてこれにてインストールは完了です。続いてMySQLの任意のバージョンをインストールして使ってみましょう。
最新版のMySQLコンテナイメージをダウンロードする
起動画面の中央上部にある
data:image/s3,"s3://crabby-images/b329b/b329b41af1bc00c751e6481887b77bb5425aaccd" alt="図8 検索結果画面 図8 検索結果画面"
今回はRecommendedの中にあるofficialを利用しますが、
CREATEを押すとmysqlのlatestのバージョンに関してDockerコンテナのダウンロードが始まります。
data:image/s3,"s3://crabby-images/ca597/ca597279768ebe030c366c7afa45e4c5cff3531e" alt="図9 ダウンロード画面 図9 ダウンロード画面"
ダウンロードが完了すると自動でDockerのコンテナが実行されます。しかし、
data:image/s3,"s3://crabby-images/1544a/1544a21718290c8257c4bcb35459af89ddac5584" alt="図10 初期画面 図10 初期画面"
何やらエラーメッセージのようなものが表示されています。
Database is uninitialized and MYSQL_ROOT_PASSWORD not set Did you forget to add -e MYSQL_ROOT_PASSWORD=... ?
内容を読んでみるとrootパスワードが設定されていないというエラーメッセージが表示されているので、
Dockerイメージの設定を変更する
右上のSettingsからメニューを開くと、
data:image/s3,"s3://crabby-images/600fb/600fb4b32b95aea5686fa4008d53cef918d4f037" alt="図11 設定画面 図11 設定画面"
設定できる項目や内容は以下の表のようになります。
名前 | 設定できる項目の種類 |
---|---|
General | コンテナ名やDockerで起動するときの環境引数をここで指定できます |
Ports | 外部のネットワークから接続する場合に、 |
Volums | コンテナがマウントするディレクトリを選択することができます。 |
Advanced | Kitematicを終了した時のVMの扱いなどを設定することができます。 |
今回はrootパスワードを設定したいのでGeneralのメニューからパスワードを引数として渡してあげます。Generalのメニュー内にあるEnviroment VariablesにMySQLのDockerのイメージ起動方法に書かれているように、
data:image/s3,"s3://crabby-images/ad0ce/ad0ce7d33e20a2489cc0347ffa088e24b2c5407c" alt="図12 パスワード設定 図12 パスワード設定"
その他にも今回は使っていませんが、
入力が終わったあとSAVEを押すと設定が保存され、
data:image/s3,"s3://crabby-images/0cd81/0cd81ec959b2799e496515f716f098e3989e3b2d" alt="図13 MySQLの起動画面 図13 MySQLの起動画面"
先ほどのエラーとは違うログが出力されていることがわかります。無事起動が完了しました。
mysqlコマンドラインツールを使って繋いでみましょう。ここではhomebrewを使ってインストールをしたものを利用してます。hostのipとportはSettingsのPortから確認できます。
$ mysql -uroot -p -h 192.168.99.100 -P 32776
Enter password: ← MySQL_ROOT_PASSWODで設定したパスワード
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.6.27 MySQL Community Server (GPL)
Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
ということで、
アプリケーションを使用している人は設定でhostとportをDockerのものに変更してあげるだけで、
続けて、
最新のMySQL5.7を試してみる
左上にあるContainersの右にある+NEWボタンを押して新規のコンテナを追加します。
data:image/s3,"s3://crabby-images/78976/7897632b0debe1e4eaa9c229b67e0af8b6072f6f" alt="図14 新規コンテナ追加 図14 新規コンテナ追加"
すると初回起動をした時と同じ画面に移ります。
data:image/s3,"s3://crabby-images/3a7ad/3a7adb6701ae1b7561832b9ba9ccecfa9ab61979" alt="図15 起動メニュー 図15 起動メニュー"
そこで先ほどと同様にMySQLを検索バーに入力します。すると下のような検索結果がやはり表示されると思います。
data:image/s3,"s3://crabby-images/67387/673879bb68b3fb03fcabbb611278dc8e03d90765" alt="図16 検索結果 図16 検索結果"
前回はそのままCREATEボタンをクリックしましたが、
data:image/s3,"s3://crabby-images/2f13c/2f13cb34d33b165f4c27ca8609b7190da59b49b0" alt="図17 メニュー内部 図17 メニュー内部"
すると下のような画面が開き、
data:image/s3,"s3://crabby-images/e390a/e390a642512d1d852cd174ff1685a3bb07f1b213" alt="図18 タグ選択画面 図18 タグ選択画面"
その後CREATEを行うとMySQL5.
Database is uninitialized and MYSQL_ROOT_PASSWORD not set Did you forget to add -e MYSQL_ROOT_PASSWORD=... ?
lastestで行った時と同様にMySQL_
$ mysql -uroot -p -h 192.168.99.100 -P 32779
Enter password: ← MySQL_ROOT_PASSWODで設定したパスワード
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.8-rc MySQL Community Server (GPL)
Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql>
このように簡単にMySQL5.
今回はMySQL5.
まとめ
今回はKitematic