Struct tikv::server::raft_client::RaftClient [−][src]
A raft client that can manages connections correctly.
A correct usage of raft client is:
for m in msgs {
if !raft_client.send(m) {
// handle error.
}
}
raft_client.flush();
Fields
pool: Arc<Mutex<ConnectionPool>>
cache: LruCache<(u64, usize), CachedQueue>
need_flush: Vec<(u64, usize)>
full_stores: Vec<(u64, usize)>
future_pool: Arc<ThreadPool<TaskCell>>
builder: ConnectionBuilder<S, R>
engine: PhantomData<E>
Implementations
impl<S, R, E> RaftClient<S, R, E> where
S: StoreAddrResolver + Send + 'static,
R: RaftStoreRouter<E> + Unpin + Send + 'static,
E: KvEngine,
[src]
S: StoreAddrResolver + Send + 'static,
R: RaftStoreRouter<E> + Unpin + Send + 'static,
E: KvEngine,
pub fn new(builder: ConnectionBuilder<S, R>) -> RaftClient<S, R, E>
[src]
fn load_stream(&mut self, store_id: u64, conn_id: usize) -> bool
[src]
Loads connection from pool.
Creates it if it doesn’t exist. false
is returned if such connection
can’t be established.
pub fn send(&mut self, msg: RaftMessage) -> Result<(), DiscardReason>
[src]
Sends a message.
If the message fails to be sent, false is returned. Returning true means the message is
enqueued to buffer. Caller is expected to call flush
to ensure all buffered messages
are sent out.
pub fn need_flush(&self) -> bool
[src]
fn flush_full_metrics(&mut self)
[src]
pub fn flush(&mut self)
[src]
Flushes all buffered messages.
Trait Implementations
impl<S, R, E> Clone for RaftClient<S, R, E> where
S: Clone,
R: Clone,
[src]
S: Clone,
R: Clone,
fn clone(&self) -> Self
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
Auto Trait Implementations
impl<S, R, E> !RefUnwindSafe for RaftClient<S, R, E>
impl<S, R, E> Send for RaftClient<S, R, E> where
E: Send,
R: Send,
S: Send,
E: Send,
R: Send,
S: Send,
impl<S, R, E> !Sync for RaftClient<S, R, E>
impl<S, R, E> Unpin for RaftClient<S, R, E> where
E: Unpin,
R: Unpin,
S: Unpin,
E: Unpin,
R: Unpin,
S: Unpin,
impl<S, R, E> !UnwindSafe for RaftClient<S, R, E>
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<V, W> ConvertFrom<W> for V where
W: ConvertTo<V>,
[src]
W: ConvertTo<V>,
pub fn convert_from(ctx: &mut EvalContext, from: W) -> Result<V, Error>
[src]
impl<T> From<T> for T
[src]
impl<T> Instrument for T
[src]
pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Pointable for T
[src]
pub const ALIGN: usize
[src]
type Init = T
The type for initializers.
pub unsafe fn init(init: <T as Pointable>::Init) -> usize
[src]
pub unsafe fn deref<'a>(ptr: usize) -> &'a T
[src]
pub unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T
[src]
pub unsafe fn drop(ptr: usize)
[src]
impl<T> Pointable for T
[src]
pub const ALIGN: usize
[src]
type Init = T
The type for initializers.
pub unsafe fn init(init: <T as Pointable>::Init) -> usize
[src]
pub unsafe fn deref<'a>(ptr: usize) -> &'a T
[src]
pub unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T
[src]
pub unsafe fn drop(ptr: usize)
[src]
impl<T> Same<T> for T
[src]
type Output = T
Should always be Self
impl<T> Sealed<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
[src]
V: MultiLane<T>,