#導入
Alibaba Cloudを利用するにあたり、導入時の比較対象となりうるパブリッククラウドとしてAmazon社提供のAmazon Web Service(通称AWS)、Microsoft社提供のMicrosoft Azure(通称Azure)、Google社提供のGoogle Cloud Platform(通称GCP)など、各社色々なサービスが提供されています。
今回、この記事でパブリッククラウドではシェアNo.1のAmazon Web ServiceとAlibaba Cloudの各コンポーネントの比較などを行いたいと思います。
比較対象として、まずは仮想サーバのコンピューティングサービスであるAmazon Elastic Compute Cloud(Amazon EC2)と、Alibaba社のElastic Compute Service(ECS)を比較してみます。
##性能諸元
それぞれのコンピューティングサービスの性能諸元は以下のページに記載があります。
各プランに関する記述は、以下から抜粋、引用させていただきました。
AWS:https://aws.amazon.com/jp/ec2/instance-types/
Alibaba Cloud:https://jp.alibabacloud.com/product/ecs#pricing
では、それぞれ概要を確認してみましょう。
##Amazon Elastic Compute Cloudのプラン
AWSのEC2はそれぞれ特徴ごとに以下のカテゴリに分けられているようです。
カテゴリ:汎用
プラン名:T2,M5,M4
T2のユースケース:Web サイトや Web アプリケーション、開発環境、ビルドサーバー、コードリポジトリ、マイクロサービス、テストやステージング環境、基幹業務アプリケーション。
個人利用としてはこのT2プランが拡張性高く安いため多く使われている印象を受けます。
カテゴリ:コンピューティング最適化
プラン名:C5,C4
C5のユースケース:ハイパフォーマンスのウェブサーバー、科学的モデリング、バッチ処理、分散分析、高性能コンピューティング (HPC)、機械学習/深層学習推論、広告サービス、拡張性の高いマルチプレイヤー、動画エンコーディング。
カテゴリ:メモリ最適化
プラン名:x1e,x1,R4
X1eのユースケース:ハイパフォーマンスデータベース、インメモリデータベース (SAP HANA など)、メモリ負荷の高いアプリケーション。x1e.32xlarge インスタンスは、AWS クラウドで、次世代ビジネススイート S/4HANA、Business Suite on HANA (SoH)、Business Warehouse on HANA (BW)、および Data Mart Solutions on HANA の実行を SAP によって認定されています。
カテゴリ:高速コンピューティング
プラン名:P3,P2,G3,F1
P3のユースケース:機械学習/深層学習関連のハイパフォーマンスコンピューティング、数値流体力学、金融工学、耐震解析、音声認識、自動運転車、創薬
これは最近流行っているGPUを用いたプランですね。クラウド技術の進歩に伴いグラフィックボードを手掛けているNVIDIAの時価総額が急上昇した要因でもあります。高度な3次元解析などではこのプランが有用そうです。
カテゴリ:ストレージ最適化
プラン名:H1,I3,D2
H1のユースケース:MapReduce ベースのワークロード、HDFS や MapR-FS などの分散型ファイルシステム、ネットワークファイルシステム、Apache Kafka などのログまたはデータ処理アプリケーション、ビッグデータワークロードクラスター。
##Alibaba Cloud Elastic Compute Serviceのプラン
同様に、AlibabaのECSはそれぞれ特徴ごとに以下のカテゴリに分けられているようです。
カテゴリ:一般目的
プラン名:コミュニケーションタイプ sn2、sn2ne
ユースケース:中規模および大規模のWebサーバー(高い並行性)に適しています。 MMO(Massively Multiplayer Online)ゲームのフロントエンド、データ解析、コンピューティングCPUが提供する高精度のエンコード/デコード、レンダリング、遺伝子計算、その他の固定性能コンピューティングのシナリオを提供しています。
カテゴリ:コンピューティング最適化
プラン名:コミュニケーションタイプ sn1、sn1ne
ユースケース:上記と同等
カテゴリ:メモリ最適化
プラン名:コミュニケーションタイプ se1、se1ne
ユースケース:Cache / Redis、検索、インメモリデータベースを持つアプリケーションなど、多数のメモリ操作、クエリ、およびコンピューティングが必要なアプリケーションに適しています。
カテゴリ:ビッグデータ
プラン名:コミュニケーションタイプ d1
ユースケース:対応するエフェメラルディスクストレージタイプ:SATA HDDリソース。膨大なストレージリソース、Hadoop、並列データ処理、その他のビジネスシナリオに適しています。
カテゴリ:ローカルSSD
プラン名:SSDタイプ i1
ユースケース:対応するエフェメラルディスクストレージタイプ:NVMe SSDリソース。高いランダムIOPS、高いシーケンシャル読み取り/書き込みスループット、および低レイテンシ
OLTP、NoSQLデータベース、Hadoop、その他のアプリケーションのシナリオに適しています。
カテゴリ:高いクロック速度
プラン名:CPUタイプ cm4、コミュニケーションタイプ ce4
ユースケース:MMO(Massively Multiplayer Online)ゲームのフロントエンド、データ解析、コンピューティングに適しています。 CPUが提供する高精度のエンコード/デコード、レンダリング、遺伝子計算、その他の固定性能コンピューティングのシナリオを提供しています。
##スペック比較してみての感想
それぞれ、カテゴリ分けもコンピューティング最適化、メモリ最適化、など似た形となっていることがわかりました。その他の項目も表現は違えどかなり似通っているように見えます。
また、これらのプランごとに、vCPU、メモリの違い(1vCPU、2GB 、 2vCPU、4GBなど)で金額が異なってきます。
個人的に気になったのはAWS側ではGPUによる高処理能力を前面に押し出したプランがあることです。今後、高度な画像処理などのサービスを見据えてのラインナップなのか、他のプランと横並びで「GPU」という言葉が用いられていました。
##実際にデプロイしてみた
では、次は実際にそれぞれのインスタンスをデプロイし、UI/UX部分を比較してみたいと思います。
多少、主観が入るかもしれませんが、みなさまがデプロイするにあたって画面遷移など参考になれば幸いです。また、ネットワークに多少依存するところもありますが、デプロイ速度などもざっくり評価してみます。
##Amazon EC2のデプロイ
まずは以下のURLから自分の持っているアカウントでサインインし、トップページにアクセスします。
https://console.aws.amazon.com/ec2
右上に自分の登録しているアカウント名が出ますので、本記事では隠させていただいています。
トップページにアクセス後画面上部の「サービス」にカーソルを合わせてクリックすると、AWS上で利用できるサービス群が表示されますので、「EC2」をクリックします。するとEC2専用のコンソール画面に遷移します。

画面の構成としては左側タブに各コンポーネントの選択があり、真ん中~右に自分の所持しているリソースが表示されます。クラウド基盤のOSSの主流であるOpenstackや、Microsoft社のAzureなども同じ画面構成ですね。では早速インスタンスの作成をしてみましょう。画面中央の「インスタンスの作成」ボタンをクリックします。

すると、ステップ1としてAmazonマシンイメージ(AMI)というページに遷移します。作成するインスタンスのOSを選択する画面になりますので、利用したいOSを選択します。この画面ではUNIXベースのOSが表示されていますが、画面をスクロールするとwindowsなどのOSも選択可能です。ここでは一番上の「Amazon Linux AMI」を選択します。

するとステップ2としてインスタンスタイプの選択という画面に遷移します。vCPU、メモリなどのインスタンスのスペックを指定します。ファミリーとして、上記で記述した「コンピューティング最適化」などのカテゴリごとに一覧化されており、基本的には下にスクロールするほどスペックが上がるようになっています。ここではファミリー:汎用のタイプ:t2.microを選択して、次の手順:インスタンスの詳細の設定をクリックします。

するとステップ3としてインスタンスの詳細の設定に遷移します。一つ一つの項目についての説明は省略します。例えば「ネットワーク」ではすでに作成しているネットワークに本インスタンスを所属させたい場合は、ここで選択を行います。ここでは何も変更せずに次の手順:ストレージの追加をクリックします。

次にステップ4としてストレージの追加に遷移します。サイズ(GB)ですが、選択したプランではデフォルトでは8GBとなっているようです。
何も変更せずに、次の手順:タグの追加をクリックします。

ステップ5としてタグの追加に遷移します。特に今回設定することはないので次の手順:セキュリティグループの設定をクリックします。

ステップ6としてセキュリティグループの設定に遷移します。ここでは作成したインスタンスのACL的な設定が実行できます。デフォルトではすべてのソースIPからのSSH接続を許可する設定が入っています。
今回は試験的にインスタンスを作成するため特に詳細な設定はしませんが、本来であれば自分のアクセス元となるIPのみSSH接続を許可するなどの設定が必要になると思います。
ここでは何も実施せずに確認と作成ボタンをクリックします。

ステップ7:インスタンス作成の確認画面として、これまで入力してきた設定内容の最終確認の画面が表示されます。問題がなければ作成をクリックします。

するとポップアップが表示され、サーバにセキュアにアクセスするためのキーペアについての作成画面が表示されます。この認証キーを使ってサーバのアクセスできるようです。ここでは新しいキーペアの作成を選択、キーペア名に「test」と入力してキーペアをダウンロードしておきました。下に.pemファイルがダウンロードされていることがわかると思います。
ダウンロードを完了した上で、インスタンスの作成をクリックします。

ローディング画面を少し挟んだのち、インスタンス作成中の画面が出ます。
その後ホーム画面に戻ると、すでにインスタンスは作成され、runningの状態でリストに存在していました。作成したインスタンスのスペックが低いとはいえ、非常に速いです。約1分ほどといったところでしょうか。


これにてインスタンスの作成が完了となります。
##EC2をデプロイしてみての感想
特にUIベースで操作に迷うことはなく、淡々と作成できました。欲を言えば、おそらくチュートリアル等には書いてあるのだと思うのですが、キーペアでの鍵認証でないbasic認証(ID/PWを用いた認証)でのSSHログインをするときに、どうしたらよいのか流れの中ではわかりませんでした。まあ鍵認証のほうがセキュアなので意図的にそうしているのかもしれませんが・・・個人的には少し気になるポイントでした。
##Alibaba Cloud ECSのデプロイ
AWSの時と同様にコンソール画面にログインします。個人情報も同様にホワイトアウトしています。
「プロダクトとサービス」の中にある「Elastic Conpute Service(ECS)」をクリックすると、ECS専用のコンソール画面に遷移します。

AmazonのAWSと比較を念頭に置いて画面を見ていきますが、まず、トップページでは各リージョン(インスタンスを置いている地域)ごとのインスタンスの状態がグラフィカルに見えているので、非常にわかりやすい印象を受けました。
ここでは、試しに「US West1(Silicon Valley)」にインスタンス作成しようと思います。「インスタンス 0」をクリックします。

すると次にインスタンスリストに「US West 1」が選択された状態で次の画面に遷移します。
現在は何もインスタンスを作成していないので、「条件を満たすレコードが見つかりません。」と表示されています。おそらくインスタンス作成後はここに作成したインスタンスの情報が表示されそうです。
右側の青いボタン「インスタンスを作成」をクリックします。

次にインスタンスの作成をする上でのパラメータを入力する画面に遷移します。
一目見て気づくのが、画面下の帯に「パッケージコスト」として現在の設定での課金金額が動的に表示されます。これはインスタンスを作成するうえでコストが一目でわかるので、金額を見ながらパラメータの選択を行うことができ、非常に便利だなと思いました。
「価格モデル」はAmazonとの比較のために「従量課金」を選択しました。「サブスクリプション」を選択すると一か月、一年単位の金額に下のパッケージコストが切り替わります。
「リージョン」は先ほど選んだ「US West 1」が「米国西部1」に和訳されて表示されています。
デフォルトで「ランダム」が選択されていましたが、ゾーンの任意選択も可能でした。ここでは「米国西部1ゾーンA」を選択しています。
画面をスクロールすると「インスタンスタイプ」を選択できます。

インスタンスタイプでは、上部「Alibaba Cloud Elastic Compute Serviceのプラン」段落で記載したプランの選択を行います。ここでは「一般目的」の「コミュニケーションタイプsn2」の「ecs.sn2.medium」を選択します。
画面をスクロールします。

イメージを選択します。プルダウンをクリックすると、パブリックイメージとして標準的なOSを利用できます。カスタムイメージは持ち込みOSなどをアップロードして利用できるようです。ここでは個人的に使いやすい「CentOS」の「6.9.64bit」を選択しました。
ストレージを選択します。容量はデフォルトで40GBとなっており、任意に変更可能でした。ここではデフォルトのままとします。
完了後、次のステップ:ネットワークをクリックします。

ネットワーク部分に関しては、VPCなどは作成していないのでデフォルトのまま次に進みます。
パブリックIPの割り当てはデフォルトのままチェックありとしておきます。
前のステップ:基本構成に隠れてしまっていますが、トラフィック毎にかかる料金も表示されるようになりました。

同じくこちらもデフォルトのまま次のステップ:システム構成をクリックします。

次にログオン資格の選択画面に遷移します。デフォルトではAmazonと同じようにキーペア式が選択されていました。ここでは手軽にログイン確認するために、AmazonのEC2とは変えてパスワード方式を選択してみます。パスワードの入力を求められるので、任意のものを入力します。
インスタンス名などは、複数のインスタンスを作成するときは間違いないように任意の名称を付けるべきですが、ここではデフォルト値のまま次のステップ:グループ化をクリックします。

ここでは特にタグ付けはせず次のステップ:プレビューをクリックします。

今まで入力してきた内容が表示されるので、確認後利用規約のチェックボックスをクリックします。
ここで今まで隠れていたパブリックトラフィック料金が見えました。このケースでは8.36円/GBでかかるようです。パッケージコストとの合算がこのインスタンスにかかる合計金額になります。やはりわかりやすいですね。
その後、インスタンスの作成をクリックします。

作成の画面遷移します。


有効化のポップアップが出た後、一分後くらいに「コンソール」をクリックすると、ECSの管理コンソールに遷移し、すでに作成したインスタンスのステータスが「実行中」になっていました。
せっかくなので、表示されていたインターネットアドレスにSSHログインをしてみました。

作成したインスタンスID名のバーチャルマシンに無事アクセスできていることが確認できると思います。
Root権限でのアクセスということでもちろん危険なので、PermitRootLoginをOffにしていただくことをお勧めします。
##ECSをデプロイしてみての感想
AmazonEC2と同じく、特にUIベースで操作に迷うことはなく、淡々と作成できましたが、個人的にはECSのほうが以下の点がわかりやすかったです。
・パッケージコストとトラフィック量の総和が動的に表示されて一目で課金額がわかる
・認証方式を簡単にパスワード方式に変更できる。
デプロイスピードも1分ほどと、申し分ないと思います。
#まとめ
AmazonEC2とAlibaba Cloud ECSを比較してみました。どちらにも一長一短、UIも微妙に違いますが、基本的な機能で大きな差はないように見えます。作成できるインスタンススペックもそこまでの差はありませんでしたので、お気に召すほうをお使いいただくとよいのではないかと思います。