Full Consensus Node
フルコンセンサスノードを使用すると、Sunriseコンセンサスレイヤーでブロックチェーンの履歴を同期できます。
チェーンのアップグレード
チェーンのアップグレードを効率化し、ダウンタイムを最小限に抑えるために、Cosmovisorを設定してノードを管理することをお勧めします。
Cosmovisorチュートリアルに従ってください。
オンチェーンアップグレードを自動化するには、次のオプションを設定します。
DAEMON_ALLOW_DOWNLOAD_BINARIES=trueバックアップ
最近のバージョンのCosmovisorを使用している場合、デフォルトの設定では、アップグレードを適用する前に状態のバックアップが作成されます。これは環境フラグを使用してオフにすることができます。
アラートと監視
アラートと監視も望ましいため、ソリューションを検討し、自分の設定に合ったものを見つけることをお勧めします。Prometheusは標準で利用可能で、さまざまなオープンソースツールがあります。
ハードウェア要件
バリデーターノードを実行するために、以下の最低ハードウェア要件が推奨されます。
メモリ:8 GB RAM(最小)
CPU:4コア
ディスク:250 GB SSDストレージ
帯域幅:ダウンロード1 Gbps / アップロード1 Gbps
プルーニングを使用しない場合は、アーカイブノードを実行しており、500 GBのSSDストレージを推奨します。
依存関係
チュートリアルはUbuntu 22.04(LTS)で行われています。環境チュートリアルに従ってください。
フルコンセンサスノードの実行
インストール
Go 1.24.2をインストールします。
初期化
chain-idとmonikerを設定します。monikerはノードの名前です。
これにより、~/.sunrise/config/に以下のファイルが生成されます。
genesis.jsonnode_key.jsonpriv_validator_key.json
ジェネシスファイルのダウンロード
Githubで現在実行中のネットワークのgenesis.jsonを確認してください。
例:メインネットの場合:
最低ガス価格の設定
RPCノードおよびバリデーターノードについて、以下の最低ガス価格の設定を推奨します。私たちはパーミッションレスのWasmチェーンであるため、この設定はコントラクトスパムや潜在的なWasmコントラクトの攻撃ベクターから保護するのに役立ちます。
$HOME/.sunrise/config/app.tomlで、最低ガス価格を設定してください。
ガス価格を高く設定しすぎないでください。バリデーターの場合、提案したブロックにトランザクションが含まれなくなります。これにより、ネットワーク全体が処理できるトランザクションの数が減少します。
オプション:シードと永続的ピアの設定
シード
「シード」は、新しく参加するバリデーターが最初に接続すべき他のバリデーターのリストを提供します。 バリデーターがネットワークに接続すると、主にpersistent_peersに接続を依存するため、seedsの重要性は低下します。
永続的ピア
「永続的ピア」は、バリデーターが常に接続を維持すべき信頼できるバリデーターのリストです。 persistent_peersにリストされているバリデーターへの接続は、ネットワークの安定性を維持するために優先されます。
オプション:追加設定
必要に応じて、$HOME/.sunrise/config/app.tomlの設定ファイルを編集してください。
enableは、APIサーバーを有効にするかどうかを定義します。
EnableUnsafeCORSは、CORSを有効にするかどうかを定義します(安全ではないため、自己責任で使用してください)。
デフォルトでは、RPCとRESTは公開されていないため、公開ノードにしたい場合は、次のように設定してください。
ストレージとプルーニングの設定
コンセンサスノードをsunrise-nodeブリッジノードに接続する場合は、トランザクションインデックスを有効にし、すべてのブロックデータを保持する必要があります。これは、config.tomlで次の設定を行うことで実現できます。
トランザクションインデックスの有効化
すべてのブロックデータの保持
そして、app.tomlでは、min-retain-blocksはデフォルト設定のままである必要があります。
過去のステートへのアクセス
過去の特定の高さでのウォレットの残高などを照会したい場合は、app.tomlでpruning = "nothing"に設定したアーカイブノードを実行する必要があります。この設定はリソースを多く消費し、かなりのストレージが必要になることに注意してください。
ストレージの要件を節約したい場合は、app.tomlでpruning = "everything"を使用してすべてをプルーニングすることを検討してください。
ローカルキーペアを作成(または復元)する
バリデーター用に新しいキーペアを作成するか、既存のウォレットを復元します。
<your-key>を任意のキー名に置き換えてください。
RISEトークンを取得する
バリデーターにボンドするためにいくつかのvRISEトークンが必要になります(手数料のためにいくつかのRISEトークンも必要です)。アクティブセットに入るには、十分なトークンが必要です。
コンセンサスノードの起動
Cosmovisorを設定し、ノードを起動するための手順に従ってください。 Cosmovisorチュートリアルを参照してください。
Cosmovisorを使用しない場合は、次のコマンドを実行してください。
ノードの同期
sunrisedデーモンを起動すると、チェーンがネットワークと同期し始めます。ネットワークとの同期時間は、設定やブロックチェーンの現在のサイズによって異なりますが、非常に長い時間がかかる可能性があります。ノードのステータスを照会するには、次のようにします。
このコマンドがtrueを返す場合、ノードはまだ同期中であることを意味します。それ以外の場合、ノードはネットワークの最新ブロックに追いついており、バリデーターノードへのアップグレードを安全に進めることができます。
最新のブロックに追いつく時間を短縮したい場合は、他のノードのスナップショットを使用することを検討してください。
オプション:スナップショットを使用する
最新のブロックに追いつく時間を短縮したい場合は、スナップショットの使用を検討してください。スナップショットを使用すると、特定の高さからノードをブートストラップできるため、ジェネシスから同期する必要がなくなります。
パートナーのPolkachuは、Sunriseネットワークの毎日のスナップショットを提供しています。最新のスナップショットURLを取得するには、彼らのWebサイトにアクセスしてください。
最終更新