mirror of
https://github.com/0glabs/0g-storage-node.git
synced 2025-01-23 21:46:17 +00:00
Add admin rpc to return sync service state (#151)
This commit is contained in:
parent
891e00fa80
commit
6ade66c086
@ -2,7 +2,7 @@ use crate::types::{LocationInfo, NetworkInfo, PeerInfo};
|
||||
use jsonrpsee::core::RpcResult;
|
||||
use jsonrpsee::proc_macros::rpc;
|
||||
use std::collections::HashMap;
|
||||
use sync::FileSyncInfo;
|
||||
use sync::{FileSyncInfo, SyncServiceState};
|
||||
|
||||
#[rpc(server, client, namespace = "admin")]
|
||||
pub trait Rpc {
|
||||
@ -27,6 +27,9 @@ pub trait Rpc {
|
||||
#[method(name = "terminateSync")]
|
||||
async fn terminate_sync(&self, tx_seq: u64) -> RpcResult<bool>;
|
||||
|
||||
#[method(name = "getSyncServiceState")]
|
||||
async fn get_sync_service_state(&self) -> RpcResult<SyncServiceState>;
|
||||
|
||||
#[method(name = "getSyncStatus")]
|
||||
async fn get_sync_status(&self, tx_seq: u64) -> RpcResult<String>;
|
||||
|
||||
|
@ -8,7 +8,7 @@ use network::{multiaddr::Protocol, Multiaddr};
|
||||
use std::collections::HashMap;
|
||||
use std::net::IpAddr;
|
||||
use storage::config::all_shards_available;
|
||||
use sync::{FileSyncInfo, SyncRequest, SyncResponse};
|
||||
use sync::{FileSyncInfo, SyncRequest, SyncResponse, SyncServiceState};
|
||||
use task_executor::ShutdownReason;
|
||||
|
||||
pub struct RpcServerImpl {
|
||||
@ -119,6 +119,17 @@ impl RpcServer for RpcServerImpl {
|
||||
}
|
||||
}
|
||||
|
||||
async fn get_sync_service_state(&self) -> RpcResult<SyncServiceState> {
|
||||
info!("admin_getSyncServiceState()");
|
||||
|
||||
let response = self.ctx.request_sync(SyncRequest::SyncState).await?;
|
||||
|
||||
match response {
|
||||
SyncResponse::SyncState { state } => Ok(state),
|
||||
_ => Err(error::internal_error("unexpected response type")),
|
||||
}
|
||||
}
|
||||
|
||||
#[tracing::instrument(skip(self), err)]
|
||||
async fn get_sync_status(&self, tx_seq: u64) -> RpcResult<String> {
|
||||
info!("admin_getSyncStatus({tx_seq})");
|
||||
|
@ -7,9 +7,10 @@ mod controllers;
|
||||
mod service;
|
||||
pub mod test_util;
|
||||
|
||||
use auto_sync::{batcher_random::RandomBatcherState, batcher_serial::SerialBatcherState};
|
||||
pub use controllers::FileSyncInfo;
|
||||
use duration_str::deserialize_duration;
|
||||
use serde::Deserialize;
|
||||
use serde::{Deserialize, Serialize};
|
||||
pub use service::{SyncMessage, SyncReceiver, SyncRequest, SyncResponse, SyncSender, SyncService};
|
||||
use std::{
|
||||
fmt::Debug,
|
||||
@ -64,3 +65,11 @@ impl InstantWrapper {
|
||||
self.0.elapsed()
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Serialize, Deserialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct SyncServiceState {
|
||||
pub num_syncing: usize,
|
||||
pub auto_sync_serial: Option<SerialBatcherState>,
|
||||
pub auto_sync_random: Option<RandomBatcherState>,
|
||||
}
|
||||
|
@ -4,7 +4,7 @@ use crate::controllers::{
|
||||
FailureReason, FileSyncGoal, FileSyncInfo, SerialSyncController, SyncState,
|
||||
MAX_CHUNKS_TO_REQUEST,
|
||||
};
|
||||
use crate::Config;
|
||||
use crate::{Config, SyncServiceState};
|
||||
use anyhow::{bail, Result};
|
||||
use file_location_cache::FileLocationCache;
|
||||
use libp2p::swarm::DialError;
|
||||
@ -74,6 +74,7 @@ pub enum SyncMessage {
|
||||
|
||||
#[derive(Debug)]
|
||||
pub enum SyncRequest {
|
||||
SyncState,
|
||||
SyncStatus {
|
||||
tx_seq: u64,
|
||||
},
|
||||
@ -99,6 +100,7 @@ pub enum SyncRequest {
|
||||
|
||||
#[derive(Debug)]
|
||||
pub enum SyncResponse {
|
||||
SyncState { state: SyncServiceState },
|
||||
SyncStatus { status: Option<SyncState> },
|
||||
SyncFile { err: String },
|
||||
FileSyncInfo { result: HashMap<u64, FileSyncInfo> },
|
||||
@ -278,6 +280,23 @@ impl SyncService {
|
||||
sender: channel::ResponseSender<SyncResponse>,
|
||||
) {
|
||||
match req {
|
||||
SyncRequest::SyncState => {
|
||||
let state = match &self.auto_sync_manager {
|
||||
Some(manager) => SyncServiceState {
|
||||
num_syncing: self.controllers.len(),
|
||||
auto_sync_serial: Some(manager.serial.get_state().await),
|
||||
auto_sync_random: manager.random.get_state().await.ok(),
|
||||
},
|
||||
None => SyncServiceState {
|
||||
num_syncing: self.controllers.len(),
|
||||
auto_sync_serial: None,
|
||||
auto_sync_random: None,
|
||||
},
|
||||
};
|
||||
|
||||
let _ = sender.send(SyncResponse::SyncState { state });
|
||||
}
|
||||
|
||||
SyncRequest::SyncStatus { tx_seq } => {
|
||||
let status = self
|
||||
.controllers
|
||||
|
Loading…
Reference in New Issue
Block a user