ヤマムギ

growing hard days.

*

AWS RDS でMySQLインスタンスを構築する

      2015/05/16

Amazon Web ServiceにはAmazon Relational Database Service というデータベースサービスがあります。
EC2に立ち上げたOSにデータベースを構築してもいいのですが、データベース管理タスクをサービスとして機能提供してくれているので、AWS上でシステム構築するのであれば、基本的にはRDSを使っていこうと思います。

EC2インスタンス上ではなくRDSでデータベースを構築するメリット

公式サイトに様々な情報がありますが、特筆すべきは下記と思います。

  • 自動バックアップとディザスタリカバリ
  • ソフトウェアの自動パッチ適用
  • CPU、ディスク、メモリ使用量に関する測定値をダッシュボードに表示
  • ホットスタンバイ(Multi-AZ配置)

MySQLインスタンスを構築する

他のサービス同様に数プロセスで完了します。

aws-rds-1

[Services]で[RDS]を選択してRDSの画面で[Instances]-[Launch DB Instance]を押します。

aws-rds-2

[Select Engine]でMySQL,PostgreSQL,ORACLE,SQLServerから選択出来るので、[MySQL]を選択して[Select]を押します。

aws-rds-3

とりあえず今回は無料利用枠をなるべく使いたいので、[No, this instance is intended for use outside of production or under the RDS Free Usage Tier]を選択して、[Next Step]を押します。

aws-rds-4

デフォルトから変更した項目

  • [DB Instance Class] まずは最低の[db.t1.micrp – 1vCPU,0.613 GiB RAM]を選択。
  • [Multi-AZ Deployment] ホットスタンバイですが、どれぐらい料金が発生するのかも知りたいのと、本番稼働するのであれば必須だろうと思い、Yesにしてます。
  • [DB Instance Identifier] インスタンス名
  • [Master Username],[Master Password],[Confirm Password]

[Allocated Storage]は後でも増やせるので最低の5GBで始めます。

[Next Step]を押します。

aws-rds-5

[Network & Security]は何も変更していません。
既存のセキュリティグループも使用出来ますが、OSのセキュリティグループの設定に引きずられるのも違うかと思いまして、[Create new Security Group]にしています。

[Database Options]では、[Database Name]を設定しています。

まだ続きがあるので下にスクロールします。

aws-rds-6

バックアップとメンテナンスの設定をします。

  • [Backup Retension Period] バックアップ保持期間は1日にしました。
  • [Backup Window] 実行時刻を2時-5時で設定しました。(UTCなので-9時間)
  • [Auto Minor Version Upgrade] 自動でパッチをあてるようにします。
  • [Maintenance Window] 日曜日9時に実行されるようにしています。(UTCなので-9時間)

aws-rds-7

[View Your DB Instances]を押して作成開始。

[Instances]ビューでステータスがavailableとなれば完了です。

EC2から接続する

セキュリティグループの設定

rds-sg

EC2のセキュリティグループIDを確認して、RDSのセキュリティグループのインバウンド送信元に設定します。
設定方法はデフォルトで操作している端末のグローバルIPアドレスが設定されていると思いますので、それを参考にして送信元をIPアドレスではなくEC2のセキュリティグループにします。

ホスト名の確認

ホスト名はEndpointという項目にあります。
「~ rds.amazonaws.com」までがホスト名です。

aws-rds-9

EC2から接続してみる

EC2にログインして、下記コマンドを実行して確認します。

[bash]
$ mysql -h -u -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 35
Server version: 5.6.22-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>
[/bash]

無事成功です。


最後までお読みいただきましてありがとうございました!

「AWS認定資格試験テキスト&問題集 AWS認定ソリューションアーキテクト - プロフェッショナル 改訂第2版」という本を書きました。

「AWS認定資格試験テキスト AWS認定クラウドプラクティショナー 改訂第3版」という本を書きました。

「ポケットスタディ AWS認定 デベロッパーアソシエイト [DVA-C02対応] 」という本を書きました。

「要点整理から攻略するAWS認定ソリューションアーキテクト-アソシエイト」という本を書きました。

「AWSではじめるLinux入門ガイド」という本を書きました。

 - AWS , ,

ad

ad

  関連記事

AWS Systems Manager Session ManagerでLinuxインスタンスのRun Asサポートを有効にする

AWS Systems Manager Session Managerの設定画面 …

Amazon Aurora Serverless 課金確認

Amazon Aurora Serverlessを使い始めてみましたの記事で書い …

AWS Transfer Family S3向けのSFTP対応サーバーをVPCで作成してEIPをアタッチ

EIPの作成 同じリージョンでEIPを作成しておきます。 SFTP対応サーバーの …

「JAWS-UG 名古屋 2022年 “re:Invent”の復習~忘年会~」に参加しました

re:Inventのおみやげも飲み物、ピザ、お寿司もたくさん。 コラボベースさん …

AWS CloudFormationでAmazon DynamoDBテーブルを作ってアイテムを追加する

デモ用にDynamoDBテーブルを作って消して、ということをたまにするので、Cl …

AWS Summit 2016 Tokyoに参加してきました (Day2)

馬込は非常に良い天気です。 泊まっている部屋が2Fでしたので窓を明けると歩いてい …

試そうとしてたらSavings Plans買っちゃいました

Savings Plansの購入画面を確認していました。 画面遷移も確認しようと …

AWS Lambda(Python3)でSelenium + Chrome Headless + でwebスクレイピングする

インターネット上に公開されている情報をDynamoDBにつっこみたいだけなので、 …

静的と動的って何ですか?と営業さんに聞かれたので端的に説明してみました

AWS認定クラウドプラクティショナーの勉強をしている営業さんに、「S3で静的オブ …

Systems Manager パブリックパラメータCLIでAWSのサービス数を出力してみました(2020/5/26)

先日のAWSのサービス数を数えてみました(2020/5/23)を見られて、お師匠 …