スタートアップサービスの作成
Dingoは、Go言語で書かれたCardanoブロックチェーンデータノードであり、Ouroboros Network Node-to-Nodeミニプロトコルファミリーを使用して、Cardanoブロックチェーン上のネットワーク通信に積極的に参加します。
⚠️ これは開発中のプロジェクトであり、現在活発に開発が進められています
このガイドでは、systemdサービスの設定方法について説明します。systemdサービスを使用してDingoノードを実行すると、コンピューターが再起動したときにDingoノードを自動的に再起動することで、稼働時間を最大化できます。以下の手順に従って始めましょう。
✅ このガイドは一般的なLinux環境を前提としています。必要に応じてコマンドとパスを調整してください。
✅ このガイドは、クイックスタートガイドをすでに完了していることを前提としています。
ステップ1 - Dingoバイナリと設定の移動
Section titled “ステップ1 - Dingoバイナリと設定の移動”Dingoバイナリを/usr/local/bin/に、設定を/etc/dingo/に移動して、システム全体からアクセスできるようにします。
バイナリをコピーします:
sudo cp ~/dingo/dingo /usr/local/bin/✅
which dingoを実行して、バイナリがコピーされたことを確認できます
設定ディレクトリを作成し、設定をコピーします:
sudo mkdir -p /etc/dingosudo cp ~/dingo/dingo.yaml /etc/dingo/ステップ2 - dingo.yamlのパスの更新
Section titled “ステップ2 - dingo.yamlのパスの更新”サービスはあなたのユーザーとして実行されますが、設定は/etc/dingo/にあるため、データベースとソケットのパスが絶対パスを使用していることを確認する必要があります。以下を実行して、$HOMEを展開した状態で設定を再生成します:
sudo bash -c "cat <<EOF > /etc/dingo/dingo.yaml# Databasedatabase: blob: plugin: \"badger\" badger: block-cache-size: 0 compression: false data-dir: \"$HOME/dingo/.dingo/badger\" gc: true index-cache-size: 0 metadata: plugin: \"sqlite\" sqlite: data-dir: \"$HOME/dingo/.dingo/metadata.db\"databasePath: \"$HOME/dingo/.dingo\"
# Mempool# `mempoolCapacity` は必須ではなく、モードの既定値を上書きする任意の設定です。# 既定値: Praos モードと通常の serve モードでは 1 MiB、Leios モードでは 25 MiB です。# モードの既定値を使うには、このキーをコメントアウトするか省略します。# mempoolCapacity: 1048576
# Mithrilmithril: aggregatorUrl: \"\" cleanupAfterLoad: true enabled: true verifyCertificates: true
# NetworkbindAddr: \"0.0.0.0\"metricsPort: 12798network: \"preview\"privateBindAddr: \"127.0.0.1\"privatePort: 3002relayPort: 3001socketPath: \"$HOME/dingo/dingo.socket\"
# StorageblockfrostPort: 0meshPort: 0storageMode: \"core\"utxorpcPort: 0EOF"📝 Blockfrost互換のHTTPエンドポイントを必要とするオペレーターは、API対応のストレージに切り替え、
blockfrostPortをゼロ以外の値に設定する必要があります。
storageMode: "api"blockfrostPort: 3000ステップ3 - Mithrilからのブートストラップ(初回実行のみ)
Section titled “ステップ3 - Mithrilからのブートストラップ(初回実行のみ)”サービスを初めて起動する前に、Mithrilスナップショットからデータベースをブートストラップします:
dingo mithril sync --config /etc/dingo/dingo.yamlこれによりスナップショットがダウンロードおよびロードされ、数時間の同期時間を節約できます。詳細はクイックスタートガイドのステップ4を参照してください。
📝 これは一度だけ行う必要があります。初回ブートストラップ後は、systemdサービスがノードの同期を維持します。
ステップ4 - dingo.serviceユニットファイルの作成
Section titled “ステップ4 - dingo.serviceユニットファイルの作成”systemdサービスファイルを作成します。YOUR_USERをあなたのユーザー名(echo $USER)に置き換えてください:
cat <<ENDFILE | sudo tee /etc/systemd/system/dingo.service > /dev/null[Unit]Description=Dingo NodeAfter=network-online.target
[Service]Type=simpleRestart=on-failureRestartSec=10User=YOUR_USERExecStart=/usr/local/bin/dingo serve --config /etc/dingo/dingo.yamlSyslogIdentifier=dingoTimeoutStopSec=5
[Install]WantedBy=multi-user.targetENDFILEステップ5 - サービスの有効化と開始
Section titled “ステップ5 - サービスの有効化と開始”起動時にサービスが実行されるように有効化し、すぐに開始します:
sudo systemctl enable dingo.servicesudo systemctl start dingo.serviceステップ6 - ステータスの確認
Section titled “ステップ6 - ステータスの確認”サービスが実行中であることを確認します:
sudo systemctl status dingo.serviceログをリアルタイムで追跡するには:
sudo journalctl -u dingo -fエラーが発生した場合に最近のログを確認するには:
sudo journalctl -u dingo -n 50 --no-pager