#この手順書について
IOSTのServiノードをGoogle Compute Engine(GCE)を使って立てる人のための手順書。なるべく簡潔に書く。
作成者はIOSTのノード(AiyaaNet)を立てたRYOHOです。Qiita初投稿なので見辛かったらスミマセン。
アイヤーネット(哎呀网)
https://twitter.com/aiyaanet
#導入前提
①インターネットに接続可能な端末(デスクトップ又はノートPC)を持っていること
→端末の性能は問わない。Google Chromeが動けばよい
②Googleアカウントを持っていること
③IOSTパートナーであり210万IOSTの投票を得ていること
→この手順書を読んでいる方はこの条件はクリアしている前提で進める。パートナー登録方法は記載しない
#①IOSTアカウントの作成
以下アドレスにアクセスする
https://explorer.iost.io/applyIOST
アクセスすると、ログインフォームが出てくるので下記の値を入力して「ログイン」を押下。
【ユーザ名】iostApply
【パスワード】Qt4v*1BV
すると、次のような画面が表示される。
画面上部の赤い文字群は今は無視してよい。入力値は以下となる。
項目名 | 設定内容 |
---|---|
Account PubKey | Generate KeyPair for meにチェックを入れればよい。自動で入力される。 |
Account Name | IOSTパートナー名と近しい半角英数文字列を入力する。【例】AiyaaNet(パートナー名) → aiyaa_net など |
IOSTパートナー登録時に使用したメールアドレスを入力すること。 |
必要な値を入力し、「私はロボットではありません」にチェックを入れて、「Create」を押下。
しばらく待つと登録が完了し、登録完了画面が表示される。
Account Nameが前画面で入力したものと同じであることを確認したら、
Private Keyと共にコピー&ペーストし、テキスト形式で必ずローカルに保存すること。
Private Keyが分からなくなるとこの後の作業が何もできなくなるので必ず保存するべし。
※無くなった場合はアカウント作成からやり無しです(´ω`)
#②Google Compute Engine(以下GCE)のセットアップ
アカウント作成が済んだら、GCEのセットアップを行う。
下記ドキュメントを参考に進めていく(筆者もこちらの手順を下敷きに記載している)
https://developers.iost.io/docs/ja/4-running-iost-node/Google-Compute-Platform.html
まず下記URLにアクセスする(ChromeでGoogleにログインした状態が好ましい)
https://console.cloud.google.com/compute/
※アクセスして「無料トライアルで300ドル~」と出てきた場合は承諾しておく。
「課金を有効にする」を押下。
次の画面で「作成」を押下したらしばし待つ。
作成が完了したら「新規VMインスタンス」を押下して値を入力していく。
画面に蛍光ペンで示す箇所に同様の値を入力していけばよい。
項目名 | 設定内容 |
---|---|
名前 | iost |
リージョン | asia-northeast1(東京) ※プルダウンで入力 |
ゾーン | asia-northeast1-b ※プルダウンで入力。 |
コア数 | 8 ※推奨値 |
メモリ | 16 ※推奨値 |
CPUプラットフォームやGPUなどはデフォルト値のままでよい。
イメージはCentOS 7を選択し、その容量は100GBを設定する。
それ以外のチェック項目は特に設定しなくてよいし、デフォルトのままでOK。
さらに、初回起動時にDockerやiwalletなどが一通りインストールされるように、スクリプトを設定しておく。
「管理」タブを選択して少し下に行くと入力欄があるので
https://developers.iost.io/docs/ja/4-running-iost-node/Google-Compute-Platform.html
に記載されているスクリプトをコピーして貼り付ける。
尚、初回起動後、このスクリプトは不要になるのでVM作成後のファイアウォール設定作業後、削除する。
「ディスク」タブを選択してディスクを指定する。
ディスク名は「data」でよい。
サイズは大きすぎると色々と他の設定の変更が必要となり、面倒なのでとりあえず2048GBとする。
(クラウドなので後で柔軟に変更できるのでご安心を)
一通り設定したら「作成」を押下する。しばし待つと作成される。
左側の「iost」を押下すると、詳細設定画面が表示される。
少し下にスクロールすると「ネットワークインターフェース」の項目がある。
一番右の「詳細を表示」を押下。
左メニューの「ファイアウォールルール」を押下。
上部の「ファイアウォールルールを作成」を押下。
必要な情報を一通り入力する(下記を参照すればOK。IPが手打ちになることに注意)
※元ドキュメントに記載の画像のため英語だが、気にせず同じように入力してOK。
IPは手打ちで「0.0.0.0/0」と入れること。
全て入力が終わったら「作成」を押下。
この作業の後、設定した先ほどスクリプトを削除しておくこと。
VMインスタンスの詳細画面で「編集」を押下し、下にスクロールしていくと
先ほど追加したスクリプトが出てくるので削除しておく。
最後に、この後作業をしていくターミナルを立ち上げる。
https://console.cloud.google.com/
↑からトップ画面に戻り、左メニューでCompute Engineを選ぶと、既に作成したVMが一覧で表示される。
右側の接続から「ブラウザウィンドウで開く」を選ぶと、別画面でコンソールが立ち上がる。
GCEでのVM作成はとりあえずここまで。ここからはコンソールでの操作を解説する。
#③コンソールでの操作手順
sudo passwd root
と入力するとパスワードを2回入力するように求められるので、連続2回同じパスワードを入力。
※パスワードの初期設定なので、既存の何かのパスワードを入力するわけではないことに注意
sudo su
rootユーザになる。
docker ps
起動しているdockerコンテナ一覧が表示される。
iwalletのコンテナのIDをここでメモしておくこと。
上記のCONTAINER IDに表示されたIDを使って、コンテナの中に入る。
※表現が正確でないかもしれないがここでは割愛させていただく
docker exec -it コンテナID /bin/bash
※コンテナID は 前コマンドで確認したIDに置き換えること
成功するとコンテナの中に入れるので、早速いくつかの設定をしていく。
./iwallet account import アカウント名 秘密鍵
※アカウント名は一番最初にIOSTアカウント作成で使用したアカウント名
秘密鍵はIOSTアカウント作成後に生成された秘密鍵
実行したら、一旦コンテナから抜ける。
exit
次に、フルノードを起動する。
curl https://raw.githubusercontent.com/iost-official/go-iost/master/script/boot.sh | bash
上記コマンドを実行し、成功するとずらずらと英文が出てくる。
Pulling iserver ... done
Creating iserver ... done
…
などと表示されて、
If you want to register Servi node, exec:
という記載が見当たれば起動成功。
ここまでの手順で起動失敗することはまず無いので、成功した前提で進める。
まず、フルノード起動後にずらずら出てくるログのうち、以下から始まる2行はコピーして保存しておく。
Your node's Public key: ここに文字列があるはず
Your node's Network ID: ここに文字列があるはず
それぞれ、公開鍵とネットIDとなる。この後使うコマンドで使用するため、
これらもローカルに保存しておくこと。
再びコンテナに入るので、下記コマンドを実行。
docker exec -it コンテナID /bin/bash
Serviノードとして登録するコマンド
./iwallet sys register 公開鍵 --net_id ネットID --account アカウント名 -s 35.176.24.11:30002
※日本語部分は下記表を見てそれぞれ置き換えた上で実行すること。
項目名 | 設定内容 |
---|---|
公開鍵 | 直前のノード起動後に出たログで保存した公開鍵 |
ネットID | 直前のノード起動後に出たログで保存したネットID |
アカウント名 | IOSTアカウント登録で使用したアカウント名 |
実行後、しばらく経って「SUCCESS」と表示されるまで待つ(40秒くらい)
次に、Serviノードでログインする。
./iwallet sys plogin --account アカウント名
※アカウント名は直前でも入力したアカウント名と同様
実行後、しばらく経って「SUCCESS」と表示されるまで待つ(40秒くらい)
最後に、iserver.ymlの修正を行う。
#④iserver.ymlの修正
コンテナから出る
exit
iserver.ymlのあるディレクトリまで移動
cd /data/iserver
iserver.ymlを修正するため、viで開く
vi iserver.yml
挿入(INSERT)モードに入る
i
下記内容に書き換える(通常のテキストエディタと同様の操作で書き換えてOK)
ノードアクセスを確認後、IOSTが状態をモニターして、マトリックスを通知するように設定をします。*これはブロックノードだけが対象
/data/iserver/iserver.yml にある を自分のノード名(アカウント名が好ましい)に編集します。
Metrics:
pushAddr: do.iost.network:80
Username: producer
Password: パスワードは関連資料を参照してください
Enable: true
Id: mainnet:
※idの部分は例えばAiyaaNetであれば id: mainnet:aiyaa_net とした
修正が終わったら、Escキーを押下する。
上書き保存して閉じる
:wq
iserver serviceを再起動する
docker restart iserver
以上でServiノードの導入は終わりです。お疲れさまでした( ´・ω・)⊃旦