Amazon RDS への移行に関するラボでは通常、既存のオンプレミスまたはクラウドでホストされているデータベースを Amazon のリレーショナル データベース サービス (RDS) に転送します。目標は、自動バックアップ、パッチ適用、モニタリング、スケーリングのための AWS のマネージド サービスを活用することで、データベース管理の運用負担を軽減することです。
目的:
- AWS CLI を使用して、Amazon RDS MariaDB インスタンスを作成します。
- EC2 インスタンス上の MariaDB データベースから Amazon RDS MariaDB インスタンスにデータを移行します。
- Amazon CloudWatch メトリクスを使用して Amazon RDS インスタンスを監視します。
概要:
- AWS CLI を使用した Amazon RDS インスタンスの作成
- アプリケーション データを Amazon RDS インスタンスに移行する
- Amazon RDS インスタンスを使用するようにウェブサイトを設定する
- Amazon RDS データベースのモニタリング
アプリケーション データベースは、アプリケーション コードとともに Amazon Elastic Compute Cloud (Amazon EC2) Linux、Apache、MySQL、および PHP (LAMP) インスタンスで実行されます。このインスタンスは T3 小型インスタンス タイプを持ち、パブリック サブネットで実行されるため、インターネット クライアントは Web サイトにアクセスできます。 CLI ホスト インスタンスは同じサブネット内に存在し、AWS コマンドライン インターフェイス (AWS CLI) を使用してインスタンスの管理を容易にします。
AWS CLI を使用した Amazon RDS インスタンスの作成:
- AWS CLI を設定します。
- Amazon RDS インスタンスの構築に必要な次の前提条件コンポーネントを作成します。
- Amazon RDS インスタンスのセキュリティ グループ ファイアウォール
- 2 つのプライベート サブネットと 1 つのデータベース サブネット グループ
- Amazon RDS MariaDB インスタンスを作成します。
- AWS マネジメント コンソールの検索バーに「EC2」と入力して選択し、EC2 マネジメント コンソールを開きます。
- ナビゲーションペインで、[インスタンス] を選択します。
- インスタンスのリストから、CLI ホスト インスタンスを選択します。
- [接続] を選択します。
- [EC2 インスタンスの接続] タブで、[接続] を選択します。
- 認証情報を使用して AWS CLI プロファイルを設定するには、EC2 Instance Connect ターミナルで次のコマンドを実行します。 「aws 構成」
- ユーザーのアクセス キーとシークレット アクセス キーを入力します。
- セキュリティ グループの作成: RDS インスタンスを保護するために CafeDatabaseSG をセットアップします。
- インバウンド ルールの追加: CafeSecurityGroup のインスタンスからの MySQL リクエスト (TCP プロトコル、ポート 3306) のみを許可します。
- プライベート サブネットの作成: 2 つのプライベート サブネット (CafeDB プライベート サブネット 1 と CafeDB プライベート サブネット 2) を確立します。
- データベース サブネット グループの作成: RDS の CafeDB サブネット グループを定義し、プライベート サブネットに関連付けます。
- CafeDatabaseSG セキュリティ グループを作成します: コマンドを実行: aws ec2 セキュリティグループの作成 --グループ名 CafeDatabaseSG --description "カフェ データベースのセキュリティ グループ" --vpc-id
出力: 今後使用するために GroupId をメモしておきます。
CafeDatabaseSG の受信ルールの作成:
コマンドを実行:
aws ec2 authorize-security-group-ingress
--グループID
--プロトコル tcp --ポート 3306
--source-group受信ルールの確認:
コマンドを実行:
aws ec2 説明セキュリティグループ
--query "SecurityGroups[*].[グループ名、グループID、IpPermissions]"
--filters "Name=グループ名,Values='CafeDatabaseSG'"CafeDB プライベート サブネット 1 を作成します
コマンドを実行:
aws ec2 サブネットの作成
--vpc-id
--cidr-block 10.200.2.0/23
--availability-zone
出力: 将来使用するために SubnetId をメモしておきます。
CafeDB プライベート サブネット 2 の作成
コマンドを実行:
aws ec2 サブネットの作成
--vpc-id
--cidr-block 10.200.10.0/23
--availability-zone
出力: 今後使用するために、SubnetId をメモしておきます。DB サブネット グループの作成
コマンドを実行:
aws rds create-db-subnet-group
--db-subnet-group-name "CafeDB サブネット グループ"
--db-subnet-group-description "カフェ用 DB サブネット グループ"
--サブネット ID
--tags "キー=名前、値= CafeDatabaseSubnetGroup"CafeDBInstance を作成します
次のコマンドを実行して、指定された構成で MariaDB インスタンスを作成します。
コマンドを実行:
aws rds create-db-instance
--db-instance-identifier CafeDBInstance
--エンジン mariadb
--エンジン バージョン 10.5.13
--db-instance-class db.t3.micro
--allocated-storage 20
--availability-zone
--db-subnet-group-name "CafeDB サブネット グループ"
--vpc-セキュリティグループ ID
-- 公開アクセス不可
--マスターユーザー名 root --マスターユーザーパスワード 'Re:Start!9'
キー設定:
- DB インスタンス識別子: CafeDBInstance
- エンジン: MariaDB (バージョン 10.5.13)
- インスタンスクラス: db.t3.micro
- 割り当てられたストレージ: 20 GB
- セキュリティグループ: CafeDatabaseSG
- ユーザー名: root
パスワード: Re:Start!9
データベース インスタンスの作成には最大 10 分かかる場合があります。DB インスタンスのステータスを監視します
作成コマンドを実行した後、次のコマンドを実行してデータベースのステータスを監視します。
コマンドを実行:
aws rds 記述-db-instances
--db-instance-identifier CafeDBInstance
--query "DBInstances[*].[Endpoint.Address,AvailabilityZone,PreferredBackupWindow,BackupRetentionPeriod,DBInstanceStatus]"
注目すべき内容: このコマンドは、エンドポイント アドレス、アベイラビリティ ゾーン、バックアップ ウィンドウ、保持期間、インスタンスのステータスなどの情報を返します。
最初はステータスが作成中と表示され、その後、変更、バックアップを経て、最終的に利用可能になります。
- データベースのステータスが「利用可能」と表示されるまで、数分ごとに status コマンドの実行を続けます。 コマンドを実行: aws rds 説明データベースインスタンス --db インスタンス識別子 CafeDBInstance --クエリ "DBInstances[*].[DBInstanceStatus]"
Amazon RDS インスタンスへのアプリケーション データの移行:
- EC2 インスタンス (CafeInstance) に接続します
ターミナルで次のコマンドを実行して、ローカルの Cafe_db データベースのバックアップを作成します。
コマンドの実行:
mysqldump --user=root --password='Re:Start!9'
--databases カフェ_db --add-drop-database >カフェデータベースバックアップ.sqlバックアップ ファイルを確認します
less コマンドを使用して、バックアップの内容を確認できます:
コマンドの実行:
少ないcafedb-backup.sql
矢印キーまたは Page Up/Down を使用して移動し、q を使用して終了します。
バックアップを Amazon RDS データベースに復元します
次のコマンドを実行して、バックアップを RDS インスタンスに復元します。実際の RDS インスタンスのエンドポイントに置き換えます:
コマンドを実行
mysql --user=root --password='Re:Start!9'
--host=
データ移行を確認する
RDS インスタンスへの対話型 MySQL セッションを開きます:
コマンドの実行:
mysql --user=root --password='Re:Start!9'
--host=
カフェデータベース
MySQL セッションに入ったら、次の SQL クエリを実行して、product テーブルのデータを確認します。
SQL
コマンドの実行:
製品から * を選択;
返されたデータが元のデータベースと一致することを確認してください。
- MySQL セッションを終了します データを確認した後、次のように入力して MySQL セッションを終了します。 コマンドを実行 終了
注: 今後のタスクのために SSH ウィンドウを開いたままにしておきます。
Amazon RDS インスタンスを使用するようにウェブサイトを設定する
AWS Systems Manager を開きます
AWS マネジメントコンソールの検索バーで「Systems Manager」を検索します。
システムマネージャーに移動します。パラメータストアへのアクセス
左側のナビゲーションペインで、[パラメータストア] を選択します。/cafe/dbUrl パラメータを編集します
[私のパラメータ] リストから、/cafe/dbUrl を選択します。
[編集] を選択してパラメータ値を変更します。データベース URL を更新します
[パラメーターの詳細] ページで、既存の値を RDS インスタンス データベース エンドポイント アドレスに置き換えます。
形式は次のようになります:
コマンドの実行:
cafedbinstance.xxxxxxx.us-west-2.rds.amazonaws.com
「変更を保存」をクリックしてパラメータを更新します。
- ウェブサイトをテストする
新しいブラウザウィンドウを開き、前に保存した CafeInstanceURL (例: http://ec2-xx-xx-xx-xx.compute-1.amazonaws.com) を貼り付けます。
カフェのウェブサイトのホームページが読み込まれるはずです。
- データベース接続を確認する ウェブサイトの「注文履歴」タブに移動します。 表示されている注文数を確認してください。これは、移行前のローカル データベースの番号と一致する必要があります。
Amazon RDS データベースのモニタリング
Amazon RDS コンソールを開きます
AWS マネジメント コンソールで、「RDS」を検索します。
RDS 管理コンソールに移動します。データベースを選択します
左側のナビゲーションペインで、[データベース] を選択します。
リストから、cafedbinstance を選択します。
データベースに関する詳細情報が表示されます。モニタリング指標の表示
[監視] タブをクリックします。
このタブには、次のような主要な指標が表示されます。
- CPU使用率
- データベース接続
- 無料ストレージスペース
- 空きメモリ
- 書き込みIOPS
- ReadIOPS
データベース接続メトリックの監視
DatabaseConnections グラフを探します。必要に応じて、指標グラフの 2 ページまたは 3 ページに移動します。
このグラフは、アクティブなデータベース接続の数を追跡します。RDS データベースに接続します
CafeInstance ターミナル ウィンドウで次のコマンドを実行して MySQL セッションを開きます:
コマンドを実行
mysql --user=root --password='Re:Start!9'
--host=
カフェデータベース
RDS インスタンスのエンドポイントに置き換えます。
- SQL クエリを実行する MySQL セッション内で次の SQL クエリを実行して、製品テーブルからデータを取得します。 SQL コマンドの実行: 製品から * を選択;
クエリは製品テーブルからデータを返す必要があります。
データベース接続グラフを確認します
RDS コンソールで、DatabaseConnections グラフをクリックします。
これで、対話型 SQL セッションからのアクティブな接続が 1 つ表示されるはずです。
グラフが更新されない場合は、1 分待ってから [更新] をクリックしてください。MySQL セッションを閉じます
CafeInstance ターミナル ウィンドウで、MySQL セッションを終了します。
コマンドを実行
終了
切断後の接続を監視する
1 分間待ってから、RDS コンソールの DatabaseConnections グラフを更新します。
接続数は 0 と表示されるはずです。他の指標を調べる
[監視] タブでグラフを確認することで、CPUUtilization、FreeStorageSpace、WriteIOPS、ReadIOPS などの追加のメトリクスを調べることができます。
以上がAmazon RDS への移行の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、DockerのMySQLメモリ使用量を最適化することを調査します。 監視手法(Docker統計、パフォーマンススキーマ、外部ツール)および構成戦略について説明します。 これらには、Dockerメモリの制限、スワッピング、およびcgroupsが含まれます

この記事では、MySQLの「共有ライブラリを開くことができない」エラーについて説明します。 この問題は、必要な共有ライブラリ(.so/.dllファイル)を見つけることができないMySQLの障害に起因しています。ソリューションには、システムのパッケージMを介してライブラリのインストールを確認することが含まれます。

この記事では、MySQLのAlter Tableステートメントを使用して、列の追加/ドロップ、テーブル/列の名前の変更、列データ型の変更など、テーブルを変更することについて説明します。

この記事では、PHPMyAdminの有無にかかわらず、LinuxにMySQLを直接インストールするのとPodmanコンテナを使用します。 それは、各方法のインストール手順を詳述し、孤立、携帯性、再現性におけるポッドマンの利点を強調しますが、

この記事では、自己完結型のサーバーレスリレーショナルデータベースであるSQLiteの包括的な概要を説明します。 SQLiteの利点(シンプルさ、移植性、使いやすさ)と短所(同時性の制限、スケーラビリティの課題)を詳しく説明しています。 c

このガイドは、HomeBrewを使用してMacOSに複数のMySQLバージョンをインストールおよび管理することを示しています。 Homebrewを使用して設置を分離し、紛争を防ぐことを強調しています。 この記事では、インストール、開始/停止サービス、および最高のPRAを詳述しています

記事では、証明書の生成と検証を含むMySQL用のSSL/TLS暗号化の構成について説明します。主な問題は、セルフ署名証明書のセキュリティへの影響を使用することです。[文字カウント:159]

記事では、MySQLワークベンチやPHPMyAdminなどの人気のあるMySQL GUIツールについて説明し、初心者と上級ユーザーの機能と適合性を比較します。[159文字]


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター
