5.1 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	html, parent, seo
| html | parent | seo | ||
|---|---|---|---|---|
| the-clio-server.html | networks-and-servers.html | 
  | 
Clioサーバー
Clioは、検証済みの台帳データに対するWebSocketまたはHTTP API呼び出しに最適化されたXRP Ledger APIサーバーです。
ClioサーバはP2Pネットワークに接続しません。代わりに、P2Pネットワークに接続されている指定されたrippledサーバからデータを抽出します。APIコールを効率的に処理することで、ClioサーバーはP2Pモードで動作するrippledサーバーの負荷を軽減することができます。
Clioは、検証済みの過去の台帳とトランザクションデータをスペース効率の良いフォーマットで保存し、rippledに比べて最大4倍少ないスペースで保存できます。ClioはCassandraまたはScyllaDBを使用し、スケーラブルな読み取りスループットを可能にします。複数のClioサーバーが同じデータセットへのアクセスを共有できるため、冗長なデータストレージや計算を必要とせず、Clioサーバーの高可用性クラスタを構築することが可能です。
Clioはrippledサーバーにアクセスする必要があり、このサーバーはClioと同じマシン上で実行することも、別々に実行することも可能です。
Clioは完全なHTTP / WebSocket APIを提供していますが、デフォルトでは、検証済みのデータのみを返します。P2Pネットワークへのアクセスを必要とするリクエストに対しては、Clioは自動的にP2Pネットワーク上のrippledサーバにリクエストを転送し、レスポンスを返します。
Clioサーバーを運用する理由
独自のClioサーバーを運用する理由には様々なものがありますが、その多くは、P2Pネットワークに接続しているrippledサーバーの負荷軽減、メモリ使用量とストレージのオーバーヘッドの低減、水平スケーリングの容易さ、APIリクエストのスループットの向上などに集約されるのではないでしょうか。
- 
rippledサーバーの負荷軽減 - Clioサーバーはピアツーピア・ネットワークに接続しません。P2Pネットワークに接続されている1つ以上の信頼できるrippledサーバーから検証済みのデータを取得するためにgRPCを使用します。したがって、Clioサーバーはリクエストをより効率的に処理し、P2Pモードで動作するrippledサーバーの負荷を軽減することができます。 - 
メモリ使用量とストレージのオーバーヘッドの低減 - ClioはデータベースとしてCassandraを使用し、データをスペース効率の良いフォーマットで保存するため、
rippledに比べて最大4倍少ないスペースで保存できます。 - 
容易な水平スケーリング - 複数のClioサーバーが同じデータセットへのアクセスを共有できるため、Clioサーバーの高可用性クラスターを構築することが可能です。
 - 
APIリクエストのスループットの向上 - Clioサーバーは、1つまたは複数の信頼できる
rippledサーバーから検証済みのデータを抽出し、このデータを効率的に保存します。そのため、APIコールを効率的に処理することができ、結果としてスループットが向上し、場合によってはレイテンシーも低下します。 
Clioサーバーの仕組み
{% inline-svg file="/img/clio-basic-architecture.svg" /%}
Clioサーバーは、トランザクションメタデータ、アカウントステート、台帳ヘッダーなどの有効な台帳データを永続的なデータストアに保存します。
ClioサーバーはAPIリクエストを受信すると、これらのデータストアからデータを検索します。P2Pネットワークからのデータを必要とするリクエストについては、ClioサーバーはリクエストをP2Pサーバーに転送し、レスポンスをクライアントに返します。
以下のいずれかが当てはまる場合、Clioは常にrippledに転送します。
ledger_indexにcurrentまたはclosedを設定している場合ledgerAPIにおいてaccounts、queueまたはfullがtrueに設定されている場合account_infoAPIにおいてqueueにtrueが設定されている場合- リクエストAPIメソッド(
"command")においてsubmit、submit_multisigned、fee、ledger_closed、ledger_current、ripple_path_find、manifest、channel_authorizeまたはchannel_verifyが設定されている場合 
関連項目
- Clio ソースコード
 - チュートリアル: