[−][src]Struct cannyls::device::Device
Lump群を格納するためのデバイス.
モジュールドキュメントも参照のこと.
Future実装
Device
はFutureを実装している.
実際の処理は、別スレッドで実行されるため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]
impl Device
pub fn spawn<F, N>(init_storage: F) -> Device where | [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( | [src] |
デバイスの起動を待機するためのFuture
を返す.
Trait Implementations
impl Drop for Device
[src]
impl Drop for Device
impl Debug for Device
[src]
impl Debug for Device
impl Future for Device
[src]
impl Future for Device
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
fn poll(&mut self) -> Poll<Self::Item, Self::Error> | [src] |
fn wait(self) -> Result<Self::Item, Self::Error> | [src] |
Block the current thread until this future is resolved. Read more
fn map<F, U>(self, f: F) -> Map<Self, F> where | [src] |
Map this future's result to a different type, returning a new future of the resulting type. Read more
fn map_err<F, E>(self, f: F) -> MapErr<Self, F> where | [src] |
Map this future's error to a different error, returning a new future. Read more
fn from_err<E>(self) -> FromErr<Self, E> where | [src] |
Map this future's error to any error implementing From
for this future's Error
, returning a new future. Read more
fn then<F, B>(self, f: F) -> Then<Self, B, F> where | [src] |
Chain on a computation for when a future finished, passing the result of the future to the provided closure f
. Read more
fn and_then<F, B>(self, f: F) -> AndThen<Self, B, F> where | [src] |
Execute another future after this one has resolved successfully. Read more
fn or_else<F, B>(self, f: F) -> OrElse<Self, B, F> where | [src] |
Execute another future if this one resolves with an error. Read more
fn select<B>(self, other: B) -> Select<Self, <B as IntoFuture>::Future> where | [src] |
Waits for either one of two futures to complete. Read more
fn select2<B>(self, other: B) -> Select2<Self, <B as IntoFuture>::Future> where | [src] |
Waits for either one of two differently-typed futures to complete. Read more
fn join<B>(self, other: B) -> Join<Self, <B as IntoFuture>::Future> where | [src] |
Joins the result of two futures, waiting for them both to complete. Read more
fn join3<B, C>( | [src] |
Same as join
, but with more futures.
fn join4<B, C, D>( | [src] |
Same as join
, but with more futures.
fn join5<B, C, D, E>( | [src] |
Same as join
, but with more futures.
fn into_stream(self) -> IntoStream<Self> | [src] |
Convert this future into a single element stream. Read more
fn flatten(self) -> Flatten<Self> where | [src] |
Flatten the execution of this future when the successful result of this future is itself another future. Read more
fn flatten_stream(self) -> FlattenStream<Self> where | [src] |
Flatten the execution of this future when the successful result of this future is a stream. Read more
fn fuse(self) -> Fuse<Self> | [src] |
Fuse a future such that poll
will never again be called once it has completed. Read more
fn inspect<F>(self, f: F) -> Inspect<Self, F> where | [src] |
Do something with the item of a future, passing it on. Read more
fn catch_unwind(self) -> CatchUnwind<Self> where | [src] |
Catches unwinding panics while polling the future. Read more
fn shared(self) -> Shared<Self> | [src] |
Create a cloneable handle to this future where all handles will resolve to the same result. Read more
Auto Trait Implementations
Blanket Implementations
impl<T> From for T
[src]
impl<T> From for T
impl<T, U> Into for T where
U: From<T>,
[src]
impl<T, U> Into for T where
U: From<T>,
impl<T, U> TryFrom for T where
T: From<U>,
[src]
impl<T, U> TryFrom for T where
T: From<U>,
type Error = !
try_from
)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error> | [src] |
impl<T> Borrow for T where
T: ?Sized,
[src]
impl<T> Borrow for T where
T: ?Sized,
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
try_from
)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error> | [src] |
impl<T> BorrowMut for T where
T: ?Sized,
[src]
impl<T> BorrowMut for T where
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T | [src] |
impl<T> Any for T where
T: 'static + ?Sized,
[src]
impl<T> Any for T where
T: 'static + ?Sized,
fn get_type_id(&self) -> TypeId | [src] |
impl<F> IntoFuture for F where
F: Future,
[src]
impl<F> IntoFuture for F where
F: Future,
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.
fn into_future(self) -> F | [src] |
impl<T> TimerExt for T where
T: Future,
[src]
impl<T> TimerExt for T where
T: Future,
fn timeout_after(self, duration: Duration) -> TimeoutAfter<Self> | [src] |
Adds the specified timeout to this future.