[][src]Struct frugalos_mds::Service

pub struct Service { /* fields omitted */ }

MDS用のサービスを表すFuture実装.

MDSノードの管理やRPC要求の処理等を担当する.

一つのサーバ(HTTPサーバ)につき、一つのサービスインスタンスが起動していることを想定.

Implementations

impl Service[src]

pub fn new(
    logger: Logger,
    rpc: &mut RpcServerBuilder,
    tracer: ThreadLocalTracer
) -> Result<Self>
[src]

新しいServiceインスタンスを生成する.

pub fn handle(&self) -> ServiceHandle[src]

Serviceを操作するためのハンドルを返す.

pub fn stop(&mut self)[src]

サービスを停止する.

サービス停止前には、全てのローカルノードでスナップショットが取得される.

サービスの停止時に考慮すべきこと

(a) すべてのノードが停止するまでに発生するノードの取得エラー(存在しない ノードへの参照)を減らすこと.

(b) 停止時のノードのスナップショット取得以降に LogSuffix を伸ばしすぎ ないこと. 次回起動に時間がかかるようになってしまうため.

ノードを順次停止することの問題点

旧実装のようにスナップショットを取得し終えたノードから順次停止して いくと存在しないノードに対するリクエストが発生しやすくなる.なぜなら、 MDS に RPC 呼び出しをするクライアント側は RPC サーバが停止するまでは 停止済みのノードに対するリクエストを送り続けてくるからである.

特にここで問題となるのは、ノードがすべて停止するまでの間に発生する、 停止済みのノードの取得失敗によるエラーであり、この状況ではクライアント 側のリトライで状況が改善しないため実質的にリトライが意味をなさない.

停止時のエラーを極力抑える新実装

上述の問題を避けるためにサービスの停止処理を以下の2段階に分ける.

  1. スナップショットの取得
  2. 1 がすべてのノードで完了するまで待ち合わせてからノードを停止

1 で Node の状態が Stopping に変更され、スナップショットの取得 もされる.スナップショットの取得が完了した際にそれを ServiceMonitored 経由で通知する.

すべてのノードがスナップショットを取得したら(あるいは、スキップ)、 Request::ExitNode に送り Node の状態を Stopped に変更 する.

この実装と Leader ノード以外もリクエストに応答できるようにする変更 を組み合わせることで停止時のエラーを減らすことが可能になっている.

新実装のデメリット

(b) について、スナップショットの取得に時間がかかる環境では LogSuffix が伸びて、スナップショット取得の効果が薄れてしまうことは許容する.

pub fn take_snapshot(&mut self)[src]

スナップショットを取得する.

pub fn start_segment_gc(&self, local_id: LocalNodeId, tx: StartSegmentGcReply)[src]

Performs segment_gc on a single node. After this command, mds sends to Synchronizer a command which contains the following:

  • machine
  • next_commit_id

pub fn stop_segment_gc(&self, local_id: LocalNodeId, tx: StopSegmentGcReply)[src]

Stops segment_gc on a single node.

Trait Implementations

impl Debug for Service[src]

impl Future for Service[src]

type Item = ()

The type of value that this future will resolved with if it is successful. Read more

type Error = Error

The type of error that this future will resolve with if it fails in a normal fashion. Read more

Auto Trait Implementations

impl !RefUnwindSafe for Service

impl Send for Service

impl !Sync for Service

impl Unpin for Service

impl !UnwindSafe for Service

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<F> IntoFuture for F where
    F: Future
[src]

type Future = F

The future that this type can be converted into.

type Item = <F as Future>::Item

The item that the future may resolve with.

type Error = <F as Future>::Error

The error that the future may resolve with.

impl<T> TimerExt for T where
    T: Future
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.