内容
オンプレミスのサーバをクラウドに移行する方法としてリホストという手法があります。これはアプリケーションの構成を変更せず、オンプレミスのサーバをそのままクラウドに移行する手法です。リホストの中でも物理サーバや仮想サーバをそのままコンバートして移行する方法があります。その際、AWSで使用可能なサービスとしてAWS Migration HubとApplication Migration Service(AWS MGN)があります。
AWS Migration Hub
AWS Mgration Hubは移行対象サーバの情報の収集、移行、移行後の追跡までの管理を行うことが可能です。情報収集を行う「検出」フェーズでは様々な方法があります。今回は移行対象サーバにエージェントをインストールを行う「AWS Application Discovery Agent」の方式を使用します。また移行ツールは移行対象サーバの情報をレプリケートしてEC2に移行する「AWS MGN」を使用します。
今回の移行の構成ですが、パブリックサブネットの中に1台EC2サーバを作成します。このEC2サーバを同じサブネットに移行する構成となります。まず移行元サーバに「AWS Application Discoverty Agent」をインストールしてAWS Migration Hubにデータ収集を行います。
パブリックサブネットおよびAmazon Linux 2023を1台構築した状態で下記を設定していきます。まず、IAMユーザを作成しAWSApplicationDiscoveryAgentAccess/AWSApplicationMigrationAgentPolicy
および下記ポリシーをIAMユーザにアタッチします。
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": "discovery:*",
"Resource": "*"
}
]
}
Discovery Agentをインストールします。インストール後systemctl status aws-discovery-daemon.service
コマンドでエージェントの状態を確認します。
curl -o ./aws-discovery-agent.tar.gz https://s3-ap-northeast-1.amazonaws.com/aws-discovery-agent.ap-northeast-1/linux/latest/aws-discovery-agent.tar.gz
tar -xzf aws-discovery-agent.tar.gz
sudo bash install -r ap-northeast-1
systemctl status aws-discovery-daemon.service
Discovery Agentからデータ収集を開始します。aws configure
で作成したIAMユーザのKeyを入力します。aws discovery describe-agents
コマンドでagent-idを確認後、aws discovery start-data-collection-by-agent-ids
コマンドを実行します。
aws configure
AWS Access Key ID [None]: XXXXXXXXXXXXX
AWS Secret Access Key [None]: XXXXXXXXXXXXX
Default region name [None]: ap-northeast-1
Default output format [None]: text
aws discovery describe-agents
aws discovery start-data-collection-by-agent-ids --agent-ids o-xxxxxxxxxxxx
Migration Hubに移動後、「検出」⇒「サーバー」の順にクリックしていくと、サーバの情報が取得されています。
また、しばらく待っているとパフォーマンス情報も取得されていることが確認出来ます。
これで検出は完了です。移行ステータスを確認すると「開始していません」の状態のため、移行フェーズに進んでいきます。
Application Migration Service(AWS MGN)
Migration Hubの「移行」⇒「ツール」タブからMGNに移動することが出来ます。
まず、AWS MGNについての説明です。こちらもエージェントを使用する方法、使用しない方法がありますが、今回はエージェントを使用します。移行元サーバにエージェントをインストールするとデータのレプリケーションサーバが起動して、レプリケーションサーバが開始されます。レプリケーション完了後、テスト、カットオーバー処理を行うことによって移行先サーバが起動します。また、各種テンプレートの設定を行うことで、レプリケーションサーバの起動設定、移行先サーバの起動設定を行うことが出来ます。
レプリケーションテンプレートの「サブネット」を移行元サーバと同様のサブネットに設定します。また「パブリックIPを作成」を「はい」に設定します。
EC2にレプリケーションエージェントをインストールします。
wget -O ./aws-replication-installer-init https://aws-application-migration-service-ap-northeast-1.s3.ap-northeast-1.amazonaws.com/latest/linux/aws-replication-installer-init
sudo chmod +x aws-replication-installer-init
sudo ./aws-replication-installer-init
The installation of the AWS Replication Agent has started.
AWS Region Name: ap-northeast-1
AWS Access Key ID: XXXXXXXXXXXXX
AWS Secret Access Key: ****************************************
Identifying volumes for replication.
Choose the disks you want to replicate. Your disks are: /dev/xvda,/dev/nvme0n1
To replicate some of the disks, type the path of the disks, separated with a comma (for example, /dev/sda,/dev/sdb). To replicate all disks, press Enter:
Identified volume for replication: /dev/nvme0n1 of size 30 GiB
All volumes for replication were successfully identified.
Downloading the AWS Replication Agent onto the source server...
Finished.
Installing the AWS Replication Agent onto the source server...
インストールが正常に完了後、MGNのコンソールに移動すると対象サーバの情報が追加されています。
テストインスタンス起動のため、起動テンプレートを修正します。「サブネット」を移行元サーバと同様のサブネットに設定し任意のセキュリティグループを設定します。起動テンプレート修正後、「デフォルトバージョンを設定」から修正したものをデフォルトバージョンにします。
しばらく待っているとレプリケーションが完了するため、「テストインスタンスを起動」をクリックします。EC2コンソールに移動すると「AWS Application Migration Service Conversion Server」という名前のテストインスタンスが起動していることを確認出来ます。
」
テスト完了後、「カットオーバーの準備完了としてマーク」を選択すると次のフェーズに進みます。
その後、「カットオーバーインスタンスを起動」⇒「カットオーバーの最終処理」を選択していくと移行が完了します。Migration Hubからも移行ステータスが完了になっていることを確認出来ます。