はじめに
Amazon Web Serviceが提供するマネージド型リレーショナルデータベースサービス「Amazon RDS」でMySQLデータベースのインスタンス(Amazon RDS for MySQLインスタンス)を作成する手順です。
Amazon RDS for MySQLインスタンス(MySQLバージョン5.6.27のMySQLデータベースサーバ)を作成し、Amazon EC2インスタンス(Amazon Linux)からMySQLデータベースへ接続して利用開始するまでの手順について記載致します。
Amazon RDSについて
Amazon RDSのサービス詳細については、以下をご参照下さい。
EC2インスタンス作成時に使用したAMI
Amazon RDS接続テスト用のEC2インスタンスについては、以下のAMIを選択して作成します。
・Amazon Linux AMI 2015.09.2 (HVM), SSD Volume Type - ami-59bdb937
Amazon RDS for MySQLインスタンス作成の事前準備
(1) Amazon RDS for MySQLインスタンス用のセキュリティグループを作成します。
Amazon RDS for MySQLインスタンスに割り当てるセキュリティグループ[example-rds-mysql-server]を作成します。
後述の手順で作成するAmazon RDS for MySQLインスタンスには[example-rds-mysql-serverセキュリティグループ]を割り当てます。
今回の例では、[example-rds-mysql-server]セキュリティグループに、[example-server]セキュリティグループからのMySQL(TCP3306ポート)を接続するようルールを追加します。
まずは、AWS Management ConsoleでAmazon RDS for MySQLインスタンスを作成するAWSアカウントへログインします。
AWS Management Consoleへのログイン後、[EC2]->[セキュリティグループ]->[セキュリティグループの作成]をクリックします。
[セキュリティグループの作成]画面が表示されます。
[インバウンド]をクリックします。
作成する「セキュリティグループ名]や[説明]を以下のように入力します。今回の例では[VPC]としてdefault-vpcを選択します。
セキュリティグループ名 | 説明 | VPC |
---|---|---|
example-rds-mysql-server | example-rds-mysql-server | default-vpcを選択する |
[ルールの追加]をクリックします。
[インバウンド]に以下のルールを追加します。追加したら[作成]をクリックし、セキュリティグループを作成します。
タイプ | プロトコル | ポート範囲 | 送信元 | Amazon RDS for MySQLへの接続を許可したいセキュリティグループの指定 |
---|---|---|---|---|
MYSQL/Aurora | TCP | 3306 | カスタムIP | example-serverセキュリティグループIDを入力する |
(2) セキュリティグループが作成された事を確認します。
[example-rds-mysql-server]セキュリティグループが作成された事を確認します。[インバウンド]に[MYSQL/Aurora]の接続ルールが設定されている事を確認します。
(3) Amazon RDS for MySQLインスタンス用のDBサブネットグループを作成します。
Amazon RDS for MySQLインスタンスを作成する際、インスタンスをどのネットワークで稼動させるか指定する為、DBサブネットグループを作成します。
AWS Management Consoleへのログイン後、[RDS]->[サブネットグループ]をクリックします。
[サブネットグループ]->[DBサブネットグループの作成]をクリックします。
[DBサブネットグループの作成]画面が表示されます。
作成するサブネットグループの[名前]や[説明]を以下のように入力します。サブネットグループをどのVPCに作成するか選択します。
名前 | 説明 | VPC ID |
---|---|---|
example-rds-mysql-server | example-rds-mysql-server | default-vpcのVPC IDを選択する |
アベイラビリティゾーンとしては[ap-northeast-1a][ap-northeast-1c]の両方を選択します。それぞれのゾーンのサブネットを選択して[追加]をクリックし、サブネットグループのサブネットを指定します。
[作成]をクリックして、DBサブネットグループを作成します。
(4) DBサブネットグループが作成された事を確認します。
DBサブネットグループが作成された事を確認します。
(5) Amazon RDS for MySQLインスタンスに割り当てるパラメータグループを作成します。
Amazon RDS for MySQLインスタンスに割り当てるパラメータグループを作成します。
AWS Management Consoleへのログイン後、[RDS]->[パラメータグループ]をクリックします。
[パラメータグループの作成]画面が表示されます。
作成するパラメータグループとして[パラメータグループファミリー]は[MySQL 5.6]、[グループ名]や[説明]を以下のように入力します。
パラメータグループファミリー | グループ名 | 説明 |
---|---|---|
mysql 5.6 | example-rds-mysql-server | example-rds-mysql-server |
(6) パラメータグループが作成された事を確認します。
Amazon RDS for MySQLインスタンス作成手順
(7) 作成するAmazon RDSインスタンスのデータベースエンジンを選択します。
Amazon RDS for MySQLインスタンスの作成を開始します。
AWS Management Consoleへのログイン後、[RDS]->[インスタンス]->[DBインスタンスの起動]をクリックします。
[エンジンの選択]画面が表示されます。
[MySQL]を選択して[選択]をクリックします。
(8) 作成するAmazon RDS for MySQLインスタンスが[本番稼動用]か[開発/テスト]か選択します。
[本番稼動用にこのデータベースを使用する予定はありますか?]画面が表示されます。
今回の例では[開発/テスト]のMySQLを選択し、[次のステップ]をクリックします。
(9) 作成するAmazon RDS for MySQLインスタンスの設定を選択及び入力します。
[DB詳細の指定]画面が表示されます。
作成するAmazon RDS for MySQLインスタンスの設定について、以下のように選択または入力していきます。
設定の選択や入力が終わったら[次のステップ]をクリックします。
設定項目 | 設定項目に選択や入力する値 |
---|---|
ライセンスモデル | General Public License |
DBエンジンのバージョン | 5.6.27 |
DBインスタンスのクラス | db.t2.micro |
Multi-AZ配置 | いいえ |
ストレージタイプ | 汎用 (SSD) |
ストレージ割り当て | 5 GB |
DBインスタンス識別子 | example-rds-mysql-server |
マスターユーザの名前 | root |
マスターパスワード | マスターユーザのパスワードを入力します。 |
パスワードの確認 | マスターユーザのパスワードを入力します。 |
(10) 作成するAmazon RDS for MySQLインスタンスの設定を選択及び入力します。
[詳細設定の設定]画面が表示されます。
作成するAmazon RDS for MySQLインスタンスの設定について、以下のように選択または入力していきます。
設定の選択や入力が終わったら[DBインスタンスの作成]をクリックします。
設定項目 | 設定項目に選択や入力する値 |
---|---|
VPC | default-vpc |
サブネットグループ | example-rds-mysql-server |
パブリックアクセス可能 | いいえ |
アベイラビリティゾーン | ap-northeast-1a |
VPCセキュリティグループ | example-rds-mysql-server |
データベースの名前 | exampledb |
DBパラメータグループ | example-rds-mysql-server |
オプショングループ | default:mysql-5-6 |
タグのスナップショットへコピー | チェックなし (デフォルト設定) |
暗号を有効化 | いいえ (いいえ以外選択できないのでこのままとする) |
バックアップの保存期間 | 7日 |
バックアップウィンドウ | 下図のように設定する |
拡張モニタリングを有効にする | いいえ |
マイナーバージョン自動アップグレード | はい |
メンテナンスウィンドウ | 下図のように設定する |
(11) Amazon RDS for MySQLインスタンスの作成が開始されます。
[作成中]画面が表示されるので少し待ちます。
以下のような画面が表示されたら[DBインスタンスの表示]をクリックします。
(12) Amazon RDS for MySQLインスタンスの作成が完了するのを待ちます。
Amazon RDs for MySQLインスタンスの作成が開始されます。
[ステータス]が[作成中]から[利用可能]になるまで待ちます。
作成するストレージタイプや容量等によりインスタンス作成完了までの所要時間は変わりますが、利用可能になるまで少々待ちます。
(13) Amazon RDS for MySQLインスタンスの作成完了を確認します。
Amazon RDs for MySQLインスタンスの[ステータス]が[作成中]から[利用可能]に変わったら作成完了です。
Amazon RDs for MySQLの[エンドポイント]に表示されているFQDNを指定する事で、セキュリティグループ[example-rds-mysql-server]で接続を許可したインスタンスから、Amazon RDs for MySQLインスタンスに対して接続出来るようになります。
Amazon EC2インスタンスから作成したAmazon RDS for MySQLインスタンスへの接続手順
(14) Amazon RDS for MySQLへの接続テスト用にAmazon EC2インスタンスを作成します。
Amazon RDS for MySQLインスタンスへの接続用として、Amazon LinuxでEC2インスタンスを新規作成します。
EC2インスタンスのセキュリティグループには、Amazon RDS for MySQLインスタンスのセキュリティグループ[example-rds-mysql-server]に対するMySQL接続許可を追加した[example-server]セキュリティグループを割り当てます。
Amazon LinuxのEC2インスタンスを作成したら、mysqlをインストールします。
[ec2-user@example-server ~]$ sudo yum -y install mysql
(15) Amazon EC2インスタンスから作成したAmazon RDS for MySQLインスタンスへ接続します。
Amazon EC2インスタンスで以下のようなmysqlコマンドを実行する事で、作成したAmazon RDS for MySQLインスタンスへ接続出来ます。
Amazon RDS for MySQLインスタンス作成時に指定したマスターユーザ名、マスターユーザのパスワードを入力して接続します。
mysql -u でマスターユーザ名を指定、-h でAmazon RDS for MySQLインスタンスのエンドポイント名を指定します。
MySQLデータベースへ接続できたら、Amazon RDS for MySQLインスタンスの作成は完了です。
[ec2-user@example-server ~]$ mysql -u root -p -h example-rds-mysql-server.carvmoii2uds.ap-northeast-1.rds.amazonaws.com
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 5.6.27-log 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>
mysql> SELECT version();
+------------+
| version() |
+------------+
| 5.6.27-log |
+------------+
1 row in set (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| exampledb |
| innodb |
| mysql |
| performance_schema |
| sys |
+--------------------+
6 rows in set (0.00 sec)
mysql> \q
[参考] Amazon RDS for MySQLインスタンスへのMySQLユーザ追加やテーブル作成手順
ここからはAmazon RDS for MySQLインスタンスにMySQLユーザを新たに追加したり、テーブルを作成する手順等について、ご参考までに記載致します。
(16) Amazon RDS for MySQLインスタンスへMySQLユーザ追加します。
Amazon RDS for MySQLインスタンスにMySQLユーザを追加したい場合、以下のようなGRANT文を実行します。
今回の例では、Amazon RDS for MySQLインスタンスにexample_userユーザを追加します。example_userユーザからのMySQL接続を許可するネットワークも指定します。こちらは例示用のネットワークとして198.51.100.0/255.255.255.0と記載していますが、実際にはEC2インスタンスを起動するプライベートサブネットのネットワークを指定したりします。
IDENTIFIED BYの部分でexample_userユーザのパスワードを指定します。
[ec2-user@example-server ~]$ mysql -u root -p -h example-rds-mysql-server.carvmoii2uds.ap-northeast-1.rds.amazonaws.com
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 9
Server version: 5.6.27-log 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> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON exampledb.* TO example_user@'198.51.100.0/255.255.255.0' IDENTIFIED BY '**************';
Query OK, 0 rows affected (0.01 sec)
mysql> GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, DROP ON exampledb.* TO example_user@'192.0.2.0/24/255.255.255.0' IDENTIFIED BY '**************';
Query OK, 0 rows affected (0.01 sec)
mysql> SELECT user, host FROM mysql.user WHERE user = 'example_user';
+--------------+----------------------------+
| user | host |
+--------------+----------------------------+
| example_user | 192.0.2.0/24/255.255.255.0 |
| example_user | 198.51.100.0/255.255.255.0 |
+--------------+----------------------------+
2 rows in set (0.00 sec)
mysql> \q
example_userユーザでAmazon RDS for MySQLユーザへ接続出来る事を確認します。
[ec2-user@example-server ~]$ mysql -u example_user -p -h example-rds-mysql-server.carvmoii2uds.ap-northeast-1.rds.amazonaws.com
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 15
Server version: 5.6.27-log 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> \q
(17) Amazon RDS for MySQLインスタンスにテーブルを作成します。
Amazon RDS for MySQLインスタンスにテーブルを作成する場合の例も記載致します。
Amazon RDS for MySQLインスタンスのタイムゾーンのデフォルトはUTCなので、JSTでデータを扱いたい場合、Amazon RDS for MySQLインスタンスのパラメータグループで「time_zone」パラメータを「Asia/Tokyo」へ変更する、または、MySQLへ接続する度に「SET SESSION time_zone = 'Asia/Tokyo'」を実行します。
今回の例では「SET SESSION time_zone = 'Asia/Tokyo'」を実行し、MySQL接続セッションのタイムゾーンをUTCからJSTへ変更した上で、作成したテーブルにレコードを追加しています。
[ec2-user@example-server ~]$ mysql -u example_user -p -h example-rds-mysql-server.carvmoii2uds.ap-northeast-1.rds.amazonaws.com
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 15
Server version: 5.6.27-log 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> CREATE TABLE `exampledb`.`example_table`( `id` int(12), `insert_date` datetime ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.02 sec)
mysql> SELECT * FROM exampledb.example_table;
Empty set (0.00 sec)
mysql> SELECT now();
+---------------------+
| now() |
+---------------------+
| 2016-02-20 17:30:15 |
+---------------------+
1 row in set (0.00 sec)
mysql> SET SESSION time_zone = 'Asia/Tokyo';
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT now();
+---------------------+
| now() |
+---------------------+
| 2016-02-21 02:30:21 |
+---------------------+
1 row in set (0.00 sec)
mysql> SELECT * FROM exampledb.example_table;
Empty set (0.01 sec)
mysql> INSERT INTO exampledb.example_table( id, insert_date) VALUES( 1, now() );
Query OK, 1 row affected (0.01 sec)
mysql> SELECT * FROM exampledb.example_table;
+------+---------------------+
| id | insert_date |
+------+---------------------+
| 1 | 2016-02-21 02:30:31 |
+------+---------------------+
1 row in set (0.01 sec)
mysql> \q
Bye
[ec2-user@example-server ~]$
長くなりましたが、以上になります。