[][src]Struct cannyls::device::Device

#[must_use]
pub struct Device { /* fields omitted */ }

Lump群を格納するためのデバイス.

モジュールドキュメントも参照のこと.

Future実装

DeviceFutureを実装している.

実際の処理は、別スレッドで実行されるためFuture::pollを呼び出さなくても進行上は支障はないが、 このメソッドによりデバイス(スレッド)の終了(正常ないし異常)を検知することが可能となる.

なおDeviceインスタンスが破棄されると、裏で動いているデバイス用のOSスレッドも停止させられるので、 Future::pollを呼び出さない場合でも、インスタンス自体は保持しておく必要がある.

デバイスを安全に停止する方法

Device::spawn関数を呼び出すとDeviceインスタンスが結果として返されるが、 同時に引数で指定されたストレージを管理するためのOSスレッドも起動される。

Deviceインスタンスのドロップ時には、そのデストラクタ内でDevice::stopメソッドが呼び出され、 対応する管理スレッドに停止リクエストが発行される。 注意すべきは、デストラクタ内ではリクエストを発行するのみであり、停止完了を待機することはないという点である。 これは、デストラクタの呼び出し元スレッドが長時間ブロックすることを避けるための挙動である

通常はこの挙動で問題が発生することはないが、もし対象Deviceでジャーナルメモリバッファが有効になっており、 かつ、Deviceのドロップ直後にプログラムが終了する場合には、ジャーナルメモリバッファの内容が ディスクに反映される前に、管理スレッドが強制終了されてしまう可能性がある(i.e., 直近の操作内容が失われる)。

これを防ぐためには、以下のように明示的にDevice::stopを呼び出し上で、Deviceの終了を待機すれば良い:

use cannyls::deadline::Deadline;
use cannyls::device::Device;
use cannyls::nvm::MemoryNvm;
use cannyls::storage::Storage;
use futures::Future;

let nvm = MemoryNvm::new(vec![0; 1024 * 1024]);
let storage = Storage::create(nvm)?;
let mut device = Device::spawn(|| Ok(storage));

// ...デバイスに対する何らかの操作...

device.stop(Deadline::Immediate);    // 管理スレッドの停止を指示
while !device.poll()?.is_ready() {}  // 停止完了を待機

Methods

impl Device[src]

pub fn spawn<F, N>(init_storage: F) -> Device where
    F: FnOnce() -> Result<Storage<N>> + Send + 'static,
    N: NonVolatileMemory + Send + 'static, 
[src]

デフォルト設定でデバイスを起動する.

設定を変更したい場合にはDeviceBuilderを使用すること.

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

デバイスを操作するためのハンドルを返す.

pub fn stop(&self, deadline: Deadline)[src]

デバイスに停止リクエストを発行する.

このメソッドが返った時点でデバイスが停止している保証はないので、 確実に終了を検知したい場合にはFuture::pollメソッド経由で知る必要がある.

なおDeviceインスタンスのドロップ時点で、そのデバイスがまだ稼働中の場合には stop(Deadline::Immediate)が自動で呼び出される. ただし、その後にデバイスの終了を待機したりはしないので注意は必要. 例えば「Deviceインスタンスをドロップして、直後に同じ設定でデバイスを起動」といったことを 行った場合には、停止中の旧インスタンスと起動した新インスタンスでリソース(e.g., ファイル)が 衝突し、エラーが発生するかもしれない. 確実な終了検知が必要なら、アプリケーションが明示的にDevice::stopを呼び出す必要がある.

pub fn wait_for_running(self) -> impl Future<Item = Self, Error = Error>[src]

デバイスの起動を待機するためのFutureを返す.

Trait Implementations

impl Debug for Device[src]

impl Drop for Device[src]

impl Future for Device[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 Device

impl Send for Device

impl !Sync for Device

impl Unpin for Device

impl !UnwindSafe for Device

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.