Hyperledger FabricをAWS上にBlockchainTemplateを使って構築する。
バージョンは1.0を利用。
概要
BlockchainTemplateはCloudFormationのテンプレートの1つ。
Hyperledger Fabric用のBlockchainTemplateを使うと、
サブネット上にEC2インスタンスを作成してその中に分散ノードが構築される。
利用時には、構築する環境の指定とインスタンス作成に必要なものを渡すだけでよい。
事前準備
BlockchainTemplateを利用するために以下の環境準備が必要。
※パブリックサブネットはNATゲートウェイへのルーティングがあるプライベートサブネットでも可。
- VPC
- インターネットゲートウェイ
- パブリックサブネット
BlockchainTemplateでのインスタンス作成のため、以下の用意が必要。
- EC2キーペア
- セキュリティグループ
- IAMロール
VPC
BlockchainTemplateを利用できるリージョンで作成する。
CIDR blockは任意の値。
DNS hostnamesは有効にする。
ネットワークACLはデフォルト。(全てのトラフィックに制限なし)
インターネットゲートウェイ
作成後、VPCにアタッチする。
VPCからルートテーブルを選択し、作成したインターネットゲートウェイをルーティングに追加する。
パブリックサブネット
インターネットゲートウェイへのルーティングのあるメインルートテーブルを利用。
外部との通信ができない設定の場合、基盤構築時にエラーとなる。
EC2キーペア
作成したインスタンスにSSH接続する場合は、作成後にダウンロードできる鍵が必要になる。
今回はSSH接続を行わないので、作成してパラメータとして指定するのみ。
セキュリティグループ
構築することが目的なので、とりあえずすべてのトラフィックを許可。
※説明の入力も必要。
IAMロール
「AmazonEC2ContainerRegistryReadOnly」「AmazonS3ReadOnlyAccess」を指定する。
「SSHAmazonEC2RoleforSSM」は基盤構築に無関係のポリシー。
作成したインスタンスにSSH接続する場合、SSHAmazonEC2RoleforSSMは不要。
基盤構築
以下のURLにある起動へのリンクからCloudFormationを起動する。
https://docs.aws.amazon.com/ja_jp/blockchain-templates/latest/developerguide/blockchain-templates-hyperledger.html
今回はVPCを作成した「米国東部 (オハイオ) リージョン (us-east-2) で起動」を選択。
スタックの名前は任意。
デフォルト値そのまま。
作成したVPC、サブネット等を指定。
インスタンスプロファイル ARNはIAMロールから参照できる。
デフォルトはt2.mediumだが、他種類も指定可能。
5分ほどで「CREATE_COMPLETE」となる。
※失敗の場合はロールバックされる。
構築確認
SSMのセッションマネージャーを利用してインスタンスにログインする。
※IAMロールにAmazonEC2RoleforSSMを追加していること。
SSH接続でインスタンスにログインでも可。
エンドポイント作成
SSM用のエンドポイントを作成する。
作成したVPCとサブネットを指定。
セキュリティグループはEC2と同じもの(制限なし)とする。
セッションログイン
SSMセッションマネージャーから基盤構築したインスタンスのセッション開始。
以下、コマンドでノードが3つ、ordererが起動していることが分かる。
sudo docker ps
ログ確認(おまけ)
セッションマネージャーの設定でCloudWatchにコマンドログを出力する。
HYPERLEDGER EXPLORER
インスタンスのパブリックDSNのポート8080にアクセスする。
http://(パブリックDSN):8080/
おわりに
・基盤構築はできたが、チェーンコードの実行はできていない。
・1つのインスタンスの中に3つのノードを立てていて、リージョン、ネットワーク、サーバーが全て同じ環境。
セキュリティを担保しつつ、ノードを作成することは容易にできるものの、
選択できるHyperledger Fabricのバージョンが「v1」しかなく、構成的にノードが分散されていないことから
可用性や冗長性を確認するようなPoCには利用しにくいと思われる。
参考
https://docs.aws.amazon.com/ja_jp/blockchain-templates/latest/developerguide/blockchain-templates-hyperledger.html
https://medium.com/coinmonks/get-started-with-blockchain-using-the-aws-hyperledger-fabric-template-an-unofficial-guide-551bc46af710