はじめに
RDBの構築手順を備忘録的にまとめてみました。
前提条件
特になし。強いて言うなら@niftyアカウント登録済みであること。
手順
- FW作成
- RDB作成
- ログ出力設定
- Timezone変更
- フェールオーバー
詳細
FW作成
RDB作成
- 続いて左ペイン[DBサーバー] -> [DBサーバー作成]
- エンジンを選択
今回はMySQL5.6系を選択しているが、適宜好みに合わせる。 - サーバー名、ゾーン、タイプ、ディスク等を入力
冗長化についてはこちらを参照 - DB名、マスタユーザー/パスワードを入力
- バックアップ、メンテナンス時間を設定
- 最後、設定内容を確認し作成
- 作成開始
完了するのに数分要する。 - 作成完了
ログ出力設定
コントロールパネルからログを閲覧できるようにするため、パラメータを変更する。
- 左ペイン[DBパラメーター]から[DBパラメーターグループ作成]をクリック
- パラメーター名、エンジンを入力
- 検索窓から「log_output」を入力し設定値を確認
「FILE」になっていれば、閲覧可能。 - 次に検索窓から「slow_query_log」を入力し検索
プルダウンから「1」を選択。スロークエリの設定はトラブルシューティング時に役立つので極力やった方がいいかも。 - 次に検索窓から「general_log」を入力し検索
プルダウンから「1」を選択。こちらは任意です。
完了後、[保存する]をクリックし、パラメーターを作成
- 保存後、それぞれ確認。
設定反映
先程作成したパラメーターグループを反映する。
- 左ペイン[DBサーバー]から対象サーバーを選択し、[選択したDBサーバーの操作]からプルダウンで設定変更を選択
- DBパラメーターグループのプルダウンから先程作成したパラメーターグループを選択し、設定変更
- 設定後確認
Timezone変更
TimezoneをUTCから変更する。これによりタイムスタンプが日本時間に合わせられる。
- 現在のTimezoneを確認
mysqlコマンドでログインする。※MySQLクライアント(Webサーバーなど)で操作
mysql
mysql -h [RDB IPアドレス] -u [ユーザー名] -p
Enter password:
~
show variables like '%time_zone';
+------------------+--------+
| Variable_name | Value |
+------------------+--------+
| system_time_zone | UTC |
| time_zone | SYSTEM |
+------------------+--------+
2 rows in set (0.00 sec)
- ストアドプロシージャの作成
ニフティクラウド側が作成したrdbadmin以外のユーザについては、Asia/Tokyoを適用させる。
MySQL
mysql> CREATE DATABASE shared;
Query OK, 1 row affected (0.00 sec)
mysql> DELIMITER |
mysql> CREATE PROCEDURE shared.`store_time_zone`()
-> IF NOT (POSITION('rdbadmin@' IN CURRENT_USER()) = 1) THEN
-> SET SESSION time_zone = 'Asia/Tokyo';
-> END IF |
Query OK, 0 rows affected (0.29 sec)
mysql> DELIMITER ;
マスターユーザー以外の新規に追加したユーザーでストアドプロシージャを作成するにはマスターユーザーでログインし下記のような権限付与を行う必要がある。
MySQL
GRANT ALL ON shared.* to ユーザー名@'%' identified by 'パスワード';
- パラメータを修正
- 検索窓で「init_connect」を検索し、以下入力
init_connect
CALL shared.store_time_zone
- 保存後、DBサーバーを再起動
- 再起動後反映されているか確認
MySQL
mysql> show variables like '%time_zone';
+------------------+------------+
| Variable_name | Value |
+------------------+------------+
| system_time_zone | UTC |
| time_zone | Asia/Tokyo |
+------------------+------------+
2 rows in set (0.00 sec)
フェールオーバー
余力があれば追記
最後に
1から冗長構成のDBを作成するよりだいぶラクです。
もうちょっとこうした方がいいなどご意見ありましたらコメントお願いします。
参考
MySQLエンジンでタイムゾーンをUTCから他のものに変更することは可能ですか?
コントロールパネルからDBログを閲覧できるようにしたいのですが、どのようにすればいいでしょうか?
DBパラメータグループ
DBログ