このチュートリアルでは、Alibaba CloudのStarter Packageサービスを使ってDockerを使ってMagentoのeコマースサイトを設定する方法を紹介します。
本ブログは英語版からの翻訳です。オリジナルはこちらからご確認いただけます。一部機械翻訳を使用しております。翻訳の間違いがありましたら、ご指摘いただけると幸いです。
#1. なぜアリババのクラウドでeコマースサイトを構築するのか
-
Alibaba Cloud上にEコマースプラットフォームを構築すると、以下のようなメリットがあります。
-
Alibaba Cloudは、毎日何百万人もの顧客にサービスを提供している世界No.1のeコマースサイトAlibaba.comをサポートしています。
アリババクラウドは、世界200以上の国と地域に61のアベイラビリティゾーンを持つプレミアクラウドサービスです。これは、Alibaba Cloudを利用することで、顧客が要求するデータを最も近い利用可能なポイントから配信し、待ち時間の問題を解消することを意味しています。 -
Alibaba Cloudは、CSA-STAR、SOC、PCI/DSS、GDPRなど、世界中のデータセンターに関連するいくつかの国際認証をサポートしています。このような認証により、Alibaba Cloud上で処理されるデータは、データセキュリティの国際基準のコンプライアンス要件を満たす最新のツールによって常に安全に保護されていることが保証されています。
-
Alibaba Cloudは、Air Asia、Fordなど、世界的に認知されている多くの企業と提携し、クライアントに優れたサービスを提供しています。
#2. 環境を整える
Eコマースサイトを構築するには、以下の要件を満たす必要があります。
- Alibaba Cloudアカウント。まだお持ちでない場合は、アカウントを設定してから次に進みます。
- インターネットに接続できるパソコン
- DockerとDocker Composeの基礎知識
- Ubuntu OS 16以上で動作する仮想マシン
#3. Alibaba Cloud Starter Package 2.0
Alibaba Cloudのスターターパッケージは、シンプルで拡張性が高く、費用対効果の高いElastic Compute Service (ECS)を利用して、お客様のクラウドホスティングのあらゆるニーズに対応し、即座にサービスを開始することができます。新しいSSDクラウド・サーバー・パッケージは、使いやすく高性能な仮想マシンとより高いデータ転送プランを大幅な割引料金で提供し、月額2.50ドルからの利用を可能にします。14のグローバルリージョンで利用できるため、サーバーのデータセンターリージョンを簡単に選択して、特定の要件を満たすことができます。各ユーザーは、同時データ転送プランで最大5つのECSインスタンスを持つことができます。
#4. ケーススタディ:スターターパッケージを使用してeコマースサイトを構築する方法
####4.1. プロジェクトの概要
プロセスをよりよく理解するために、このチュートリアルでは、Magentoフレームワーク、Docker、Docker Compose、Alibaba Cloud Starter Packageを使用してEコマースウェブサイトを構築するシナリオを示します。
MagentoはPHPで書かれたオープンソースのeコマースプラットフォームです。トランザクションオプション、マルチストア機能、ロイヤルティプログラム、商品の分類とショッパーフィルタリング、プロモーションルールなどが含まれています。Dockerを使わずにMagentoをインストールすると、複数の設定が必要になるため、非常に複雑で、完了までに多くの時間がかかります。Dockerは、技術を非常に短い時間で立ち上げて実行できるようにすることで、開発者の生活を楽にしてくれます。スケーラビリティのために、多くのコンテナを同時に実行することができるので、Docker Composeは複数のコンテナを同時に実行するプロセスを支援します。
####4.2. スターターパッケージを入手する
前項で述べたプロジェクトを実装するために、Starter Packageには以下のオプションがあります。
- 1 Core CPU
- 1 GB RAM
- 25 GB SSD
- 2 TB Data Transfer
上記の仕様でプランを選択するには、以下のステップを踏む必要があります。
ステップ1. アリババアカウントでログイン
アリババクラウドのホームページにアクセスし、画面右上の「ログイン」をクリックします。
ステップ2. Alibaba Cloudスターターパッケージインスタンスを購入する
ログインしたら、以下の画面からStarter Packageオプションを選択します。
**ステップ2a.**Starter Packageバンドルを選択したら、以下のように画面左下の「今すぐ購入」をクリックしてパッケージの購入に進みます。
**ステップ2b.**さて、以下のように「注文を確定する」をクリックして注文を確定します。
**ステップ2c.**次の画面で、ご注文を確認し、下記のように「お支払い」をクリックしてお支払いをしてください。
決済処理が完了すると、お祝いのメッセージが表示されたポップアップ画面が表示されます。
これで、購入したばかりのインスタンスを実行して、アプリケーションを構築、デプロイ、管理したり、プランに含まれるサービスを利用することができるようになります。
**ステップ3.**インスタンスの作成と選択
Starter Package Elastic Computing Service (ECS) インスタンスを購入した後は、コンテナ化された環境で Magento アプリケーションを実行できるインスタンスを作成して実行する必要があります。
そのためには、請求管理セクションに移動して、ECS インスタンスが実行されているかどうかを確認するために注文を確認する必要があります。管理リンクをクリックして、VNC や SSH クライアントを介して接続できるパブリック IP アドレスなどの仮想マシンの詳細情報を得ることができます。このプロジェクトのインスタンスのIPは47.74.218.106です。
ステップ4. インスタンスに接続する
VMのIPアドレスを取得したら、SSHでVMに接続し直します。ここではPuttyというソフトを使って実装します。以下は参考までにPuttyのログオン画面です。
SSH経由でリモートVMへの設定に成功すると、以下のような画面が表示され、VM内でMagento CMSを実行するために必要なコマンドをすべて実行できるようになります。
####4.3. Magento のインストールとデプロイ
ステップ1. DockerとDocker Composeをインストールする
Docker Composeのインストールは非常に簡単です。まず、以下のコマンドを実行して、DockerのGitHubリポジトリからパッケージを取得します。
ステップ1a. Dockerをインストールする
$ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | apt-key add -
$ echo "deb [arch=amd64] https://download.docker.com/linux/ubuntu xenial stable" | sudo tee -a /etc/apt/sources.list.d/docker.list
$ apt-get update
$ apt-get install docker-ce -y
ステップ1b. Docker Composeをインストールする
Docker Composeのパッケージをダウンロードしてインストールするには、以下のコマンドを実行する必要があります。
$ sudo curl -L https://github.com/docker/compose/releases/download/1.18.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
次に、set /usr/local/bin/docker-composeを実行ファイルとして以下のコマンドを実行してインストールします。
インストールが成功したかどうかを確認するには、コマンドを実行します。$ docker-compose --version. これでインストールされたバージョンが表示されます。
ステップ2. コンテナ化された環境でMagentoを実行する
YAMLファイルを自分で作成する代わりに、Dockerhub上にあるBitnamiが提供しているものを以下のコマンドでクローンすることができます。
$ curl -sSL https://raw.githubusercontent.com/bitnami/bitnami-docker-magento/master/docker-compose.yml > docker-compose.yml
.ymlファイルから引っ張ってきた画像を以下のコマンドで実行するだけです。
$ docker-compose up -d
ヒント:
- 上記のコマンドはデタッチドモードで実行されているため、コマンドがバックグラウンドで実行されている間もターミナルウィンドウを使用することができます。
- コンテナを停止したい場合は、docker-compose down コマンドを使用してください。
- ターミナル上で docker ps コマンドを実行すると、システム上のすべてのコンテナのリストを取得することができます。
注意:
- 上のスクリーンショットでは、コンテナ化された環境でMagentoを実行するには、bitnami/magentoとbitnami/mariadbを2つのコンテナで実行する必要があることがわかります。
- また、Magento サーバーは、サーバーのポート 80 (http) と 443 (https) で動作しています。したがって、これらのポート(デフォルトでは閉じられています)は、ウェブサーバ経由でアプリケーションにアクセスできるようにするために、VM上で開いておく必要があります。
ポート 80 と 443 を開きます。
デフォルトでは、セキュリティ上の理由からポート80と443は無効になっています。これらのポートを開くには、次の画面に示すように、デフォルトのセキュリティグループのポート22の設定を優先度1でクローン化する必要があります。
これで、コンテナが起動し、ポート80(http)と443(https)が開いています。これで、ブラウザを開いて http://47.74.218.106
にアクセスし、以下のページを見ることができるようになったことを意味しています。
アプリの起動に成功すると、以下のようなページが表示されるはずです。
あなたは今、あなた自身のストアを設定するようにMagentoの管理ページを訪問したい場合があります。そこで、あなたがしなければならないのは http://47.74.218.106/admin
にアクセスして、以下の認証情報を使用してログインすることです。
ユーザー名:ユーザー
パスワード:bitnami1
ログインすると、Magentoの管理画面にアクセスできます。
N.B: IP アドレス 47.74.218.106 はインスタンスのパブリック IP であり、これはこのプロジェクトのために購入したばかりのインスタンスに固有のものであることに気づきましょう。したがって、購入するインスタンスによって異なることになります。
#5. 次に行く場所
下記のように、多くの可能な最適化オプションが用意されています。
- 簡単にトラフィックのスパイクを処理するためにウェブサイトにロードバランサーを追加する
- 2つ以上のアベイラビリティゾーンにウェブサイトを展開する
#結論
このチュートリアルで説明したすべての手順に従っていただければ、Docker Composeをシステムにインストールする方法、Docker Composeを使って複数のコンテナを実行する方法、そしてコンテナ化された環境にMagento CMSを正常にインストールする方法を理解していただけたと思います。
アリババクラウドは日本に2つのデータセンターを有し、世界で60を超えるアベラビリティーゾーンを有するアジア太平洋地域No.1(2019ガートナー)のクラウドインフラ事業者です。
アリババクラウドの詳細は、こちらからご覧ください。
アリババクラウドジャパン公式ページ