Solana バリデータ - クイックスタート

Installation & Validator Launch

bash
curl -fsSL https://storage.slv.dev/slv/install | sh slv validator init slv validator deploy

Usage

bash
slv v --help

Solana テストネットに Firedancer バリデータをデプロイ

サーバーには Ubuntu 24.04 LTS がクリーンインストールされている必要があります。

このコマンドを実行すると、デプロイに必要な情報を入力するよう求められます。

新しい SLV デプロイでは、常に unstaked-keypair.json がアイデンティティキーとして使用されます。 これは二重投票などを防ぐためのベストプラクティスです。

そのため、デプロイ後に slv v set:identity を使用して認証済みのアイデンティティキーをセットしてください。

デフォルトのユーザー名を入力

通常、デフォルトのユーザー名は ubuntu です。

bash
slv v init ? What's the user for the server? (ubuntu) › ubuntu

サーバーの IP アドレスを入力

サーバーの IP アドレスを入力します。

bash
? What's the IP address of the server? ›

SSH 用の RSA キーを設定

※ ご自身の RSA キーのパスを設定してください。デフォルトのパスは ~/.ssh/id_rsa です。 現在はデフォルトパスのみサポートされているため、そのまま設定してください。

bash
? What's the path to your RSA key? (~/.ssh/id_rsa) › ~/.ssh/id_rsa 🔍 Checking SSH connection... ✔︎ SSH connection succeeded

その後、SLV がサーバーへの接続をチェックします。接続が成功すると、次のステップへ進みます。

solv ユーザーのパスワードを設定

サーバー上の solv ユーザー用のパスワードを設定してください。

8文字以上で、数字・大文字・小文字の英字を含めてください。

bash
? Please enter your password › ********* ? Please confirm your password › ********* ✔︎ Password saved to ~/.slv/config.pwd.yml

暗号化されたパスワードは ~/.slv/config.pwd.yml に保存されます。

Solana ネットワークを選択

デプロイしたい Solana ネットワークを選択します。

bash
? Select Solana Network (testnet) ❯ testnet mainnet

※ 現在は testnet のみサポートされています。

Solana バリデータのアイデンティティキーを生成または設定

新しいアイデンティティキーを生成するか、既存のアイデンティティキーを設定できます。 ここでは既存のアイデンティティキーを設定する例を示します。

bash
? Do you want to create a new identity key now? (Y/n) › No ? Please Enter Your Identity Public Key › EjDwu2Czy8eWEYRuNwtjniYks47Du3KNJ6JY9rs3aFSV ⚠️ Please place your identity key in ~/.slv/keys/EjDwu2Czy8eWEYRuNwtjniYks47Du3KNJ6JY9rs3aFSV.json . . ✔︎ Success ✔ Inventory updated to ~/.slv/inventory.yml ✔ Successfully created solv user on x.x.x.x

アイデンティティキーを ~/.slv/keys/<your-pubkey>.json に配置してください。その後、SLV がパスワードを用いて solv ユーザーを作成します。

Solana バリデータの投票アカウントキーを生成または設定

新しい投票アカウントキーを生成するか、既存の投票アカウントキーを設定できます。 ここでは既存の投票アカウントキーを設定する例を示します。

bash
? Do you want to create a new vote account key now? (Y/n) › No ? Please Enter Your Vote Account Public Key > <your-vote-account> ⚠️ Please place your voteAccount pubkey in ~/.slv/keys/<your-vote-account>.json

投票アカウントキーを ~/.slv/keys/<your-vote-account>.json に配置してください。

投票アカウントの Authrority キーを入力

投票アカウントから報酬を引き出すために使用する Aurhority の PublicKey を入力してください。

bash
? Please Enter Your Vote Account's Authrority Key › <your-authority-pubkey> ✔︎ Validator testnet config saved to ~/.slv/config.validator.testnet.yml Now you can deploy with: $ slv v deploy -n testnet

これで設定内容が ~/.slv/config.validator.testnet.yml に保存されました。

バリデータのデプロイ

設定を確認したら、デプロイを開始します。

bash
slv v deploy -n testnet Your Testnet Validators Settings: ┌────────────────┬──────────────────────────────────────────────┐ │ Identity Key │ EjDwu2Czy8eWEYRuNwtjniYks47Du3KNJ6JY9rs3aFSV │ ├────────────────┼──────────────────────────────────────────────┤ │ Vote Key │ EwoVPLUhdhm722e7QWk8GMQ43917qRXiC9HFyefEMiSV │ ├────────────────┼──────────────────────────────────────────────┤ │ Authority Key │ EcT4NsMPwxanusdy3dza5nznqwuKo9Pz3GzW5GPD32SV │ ├────────────────┼──────────────────────────────────────────────┤ │ IP │ x.x.x.x │ ├────────────────┼──────────────────────────────────────────────┤ │ Validator Type │ firedancer │ ├────────────────┼──────────────────────────────────────────────┤ │ Version │ 0.302.20104 │ └────────────────┴──────────────────────────────────────────────┘ ? Do you want to continue? (Y/n) › Yes

完了です!Solana バリデータがデプロイされました。Solana ネットワークとの同期には少し時間がかかります。

次に、アンステーク済みのキーから認証済みのアイデンティティキーに変更する必要があります。

アイデンティティキーの変更

デプロイ後、アンステーク済みのキーを認証済みのアイデンティティキーに変更する必要があります。

bash
slv v set:identity -n testnet --pubkey <your-identity-pubkey>

このコマンドにより、アイデンティティキーが認証済みのキーに変更されます。 コマンドは firedancer を停止し、アイデンティティキーを変更して再起動します。

※ Firedancer では現時点でノーダウンタイム・マイグレーションは利用できません。対応が可能になり次第アップデートします。

Firedancer の再起動

バリデータに問題がある場合は、以下のコマンドで firedancer を再起動できます。

--rm オプションを使用すると、バリデータが停止し、ledger と snapshot ディレクトリが削除された後、snapshot finder でスナップショットをダウンロードしてからバリデータを起動します。

bash
slv v restart -n testnet --pubkey <your-identity-pubkey> --rm

SLV Validator コマンド

bash
Usage: slv validator Version: 0.3.1 Description: Manage Solana Validator Nodes Options: -h, --help - Show this help. Commands: init - Initialize a new validator deploy - Deploy Validators list - List validators set:identity - Set Validator Identity set:unstaked - Set Validator Identity to Unstaked Key Stop/Change Identity/Start restart - Restart validator