MySQLを開発に使っている時に、
今回はDockerを使って5.
デモンストレーション環境について
今回はDockerでMySQLの環境を複数用意して見るために、
data:image/s3,"s3://crabby-images/04a67/04a677733141f6c915772d9d94c4b3dd04254f4c" 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/e0e54/e0e54ba45dc36512c8ff8751710fffe4778879f6" alt="図2 Kitematicダウンロード画面 図2 Kitematicダウンロード画面"
インストーラを起動すると次の画面が表示されます。
data:image/s3,"s3://crabby-images/4ed0c/4ed0c39d6113cfadd2ac93ddb02e9f371a58e0d6" alt="図3 インストール画面1 図3 インストール画面1"
続けるをどんどん押していきます。一部パスワードを求められますので、
data:image/s3,"s3://crabby-images/95647/95647d222be208d59bd388cd2bdbfce6c5bfdfca" alt="図4 パスワード入力画面 図4 パスワード入力画面"
終了画面のひとつ前の画面で、
data:image/s3,"s3://crabby-images/f7155/f7155da381122af13caad7e172c5c47504869f12" alt="図5 QuickStart画面 図5 QuickStart画面"
続けるを押してインストールが完了します。続けて初期設定に移ります。
data:image/s3,"s3://crabby-images/deee2/deee25730e2867a5d327f7dafd59a2cb24e9fc2c" alt="図6 初期設定画面 図6 初期設定画面"
DockerHubアカウントをお持ちの場合は入力してください。DockerHubはDockerコンテナを公開するためのWebサービスでDockerレジストリを構築することができるので便利ですが、
data:image/s3,"s3://crabby-images/5a01d/5a01dceb61c45fdcd40d1a2fcfb2051848922ed7" alt="図7 起動画面 図7 起動画面"
さてこれにてインストールは完了です。続いてMySQLの任意のバージョンをインストールして使ってみましょう。
最新版のMySQLコンテナイメージをダウンロードする
起動画面の中央上部にある
data:image/s3,"s3://crabby-images/aa885/aa885ed9450f7f7d54e3e10e91160f3201ad2868" alt="図8 検索結果画面 図8 検索結果画面"
今回はRecommendedの中にあるofficialを利用しますが、
CREATEを押すとmysqlのlatestのバージョンに関してDockerコンテナのダウンロードが始まります。
data:image/s3,"s3://crabby-images/93dd0/93dd04a6c8a4741ad2d2a10030d953e663206b56" alt="図9 ダウンロード画面 図9 ダウンロード画面"
ダウンロードが完了すると自動でDockerのコンテナが実行されます。しかし、
data:image/s3,"s3://crabby-images/6dbb1/6dbb1ff733145ab5ce40fff739d94260cc190d83" 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/1354c/1354cfc422aa8658516b3ab18688c98c2fd69319" alt="図11 設定画面 図11 設定画面"
設定できる項目や内容は以下の表のようになります。
名前 | 設定できる項目の種類 |
---|---|
General | コンテナ名やDockerで起動するときの環境引数をここで指定できます |
Ports | 外部のネットワークから接続する場合に、 |
Volums | コンテナがマウントするディレクトリを選択することができます。 |
Advanced | Kitematicを終了した時のVMの扱いなどを設定することができます。 |
今回はrootパスワードを設定したいのでGeneralのメニューからパスワードを引数として渡してあげます。Generalのメニュー内にあるEnviroment VariablesにMySQLのDockerのイメージ起動方法に書かれているように、
data:image/s3,"s3://crabby-images/57a5d/57a5d639f32baec83a45bba58435fdf1a2535c90" alt="図12 パスワード設定 図12 パスワード設定"
その他にも今回は使っていませんが、
入力が終わったあとSAVEを押すと設定が保存され、
data:image/s3,"s3://crabby-images/ba903/ba9038a6eb241ca5a24ead19125a1724b232c617" 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/943e6/943e61dbc4a83e344472553f23d59c887e95b8c3" alt="図14 新規コンテナ追加 図14 新規コンテナ追加"
すると初回起動をした時と同じ画面に移ります。
data:image/s3,"s3://crabby-images/e0047/e00479f0872c3f9ef3272edf845d759f55525108" alt="図15 起動メニュー 図15 起動メニュー"
そこで先ほどと同様にMySQLを検索バーに入力します。すると下のような検索結果がやはり表示されると思います。
data:image/s3,"s3://crabby-images/67351/6735141b76d438375fe13b18c243292c6b950918" alt="図16 検索結果 図16 検索結果"
前回はそのままCREATEボタンをクリックしましたが、
data:image/s3,"s3://crabby-images/9995a/9995a218ee2b685391437bc7825d942f9a6afd5f" alt="図17 メニュー内部 図17 メニュー内部"
すると下のような画面が開き、
data:image/s3,"s3://crabby-images/54d63/54d63af465ca9dccff74a3f6cdee1b2bef26fc9a" 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