mirror of
https://github.com/fafhrd91/actix-net
synced 2024-11-30 19:54:36 +01:00
add blocking mod support
This commit is contained in:
parent
f1d4bcef4b
commit
bef199f831
@ -4,11 +4,12 @@
|
|||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
|
||||||
|
* Added `blocking` module
|
||||||
|
|
||||||
* Arbiter::exec_fn - execute fn on the arbiter's thread
|
* Arbiter::exec_fn - execute fn on the arbiter's thread
|
||||||
|
|
||||||
* Arbiter::exec - execute fn on the arbiter's thread and wait result
|
* Arbiter::exec - execute fn on the arbiter's thread and wait result
|
||||||
|
|
||||||
|
|
||||||
## [0.2.0] - 2019-03-06
|
## [0.2.0] - 2019-03-06
|
||||||
|
|
||||||
* `run` method returns `io::Result<()>`
|
* `run` method returns `io::Result<()>`
|
||||||
|
@ -18,9 +18,14 @@ name = "actix_rt"
|
|||||||
path = "src/lib.rs"
|
path = "src/lib.rs"
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
log = "0.4"
|
|
||||||
bytes = "0.4"
|
bytes = "0.4"
|
||||||
|
derive_more = "0.14"
|
||||||
futures = "0.1.25"
|
futures = "0.1.25"
|
||||||
|
parking_lot = "0.7"
|
||||||
|
lazy_static = "1.2"
|
||||||
|
log = "0.4"
|
||||||
|
num_cpus = "1.10"
|
||||||
|
threadpool = "1.7"
|
||||||
tokio-current-thread = "0.1"
|
tokio-current-thread = "0.1"
|
||||||
tokio-executor = "0.1.5"
|
tokio-executor = "0.1.5"
|
||||||
tokio-reactor = "0.1.7"
|
tokio-reactor = "0.1.7"
|
||||||
|
88
actix-rt/src/blocking.rs
Normal file
88
actix-rt/src/blocking.rs
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
//! Thread pool for blocking operations
|
||||||
|
|
||||||
|
use std::fmt;
|
||||||
|
|
||||||
|
use derive_more::Display;
|
||||||
|
use futures::sync::oneshot;
|
||||||
|
use futures::{Async, Future, Poll};
|
||||||
|
use parking_lot::Mutex;
|
||||||
|
use threadpool::ThreadPool;
|
||||||
|
|
||||||
|
/// Env variable for default cpu pool size
|
||||||
|
const ENV_CPU_POOL_VAR: &str = "ACTIX_CPU_POOL";
|
||||||
|
|
||||||
|
lazy_static::lazy_static! {
|
||||||
|
pub(crate) static ref DEFAULT_POOL: Mutex<ThreadPool> = {
|
||||||
|
let default = match std::env::var(ENV_CPU_POOL_VAR) {
|
||||||
|
Ok(val) => {
|
||||||
|
if let Ok(val) = val.parse() {
|
||||||
|
val
|
||||||
|
} else {
|
||||||
|
log::error!("Can not parse ACTIX_CPU_POOL value");
|
||||||
|
num_cpus::get() * 5
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Err(_) => num_cpus::get() * 5,
|
||||||
|
};
|
||||||
|
Mutex::new(
|
||||||
|
threadpool::Builder::new()
|
||||||
|
.thread_name("actix-web".to_owned())
|
||||||
|
.num_threads(default)
|
||||||
|
.build(),
|
||||||
|
)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
thread_local! {
|
||||||
|
static POOL: ThreadPool = {
|
||||||
|
DEFAULT_POOL.lock().clone()
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Blocking operation execution error
|
||||||
|
#[derive(Debug, Display)]
|
||||||
|
pub enum BlockingError<E: fmt::Debug> {
|
||||||
|
#[display(fmt = "{:?}", _0)]
|
||||||
|
Error(E),
|
||||||
|
#[display(fmt = "Thread pool is gone")]
|
||||||
|
Canceled,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Execute blocking function on a thread pool, returns future that resolves
|
||||||
|
/// to result of the function execution.
|
||||||
|
pub fn run<F, I, E>(f: F) -> CpuFuture<I, E>
|
||||||
|
where
|
||||||
|
F: FnOnce() -> Result<I, E> + Send + 'static,
|
||||||
|
I: Send + 'static,
|
||||||
|
E: Send + fmt::Debug + 'static,
|
||||||
|
{
|
||||||
|
let (tx, rx) = oneshot::channel();
|
||||||
|
POOL.with(|pool| {
|
||||||
|
pool.execute(move || {
|
||||||
|
if !tx.is_canceled() {
|
||||||
|
let _ = tx.send(f());
|
||||||
|
}
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
CpuFuture { rx }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Blocking operation completion future. It resolves with results
|
||||||
|
/// of blocking function execution.
|
||||||
|
pub struct CpuFuture<I, E> {
|
||||||
|
rx: oneshot::Receiver<Result<I, E>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<I, E: fmt::Debug> Future for CpuFuture<I, E> {
|
||||||
|
type Item = I;
|
||||||
|
type Error = BlockingError<E>;
|
||||||
|
|
||||||
|
fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
|
||||||
|
let res = futures::try_ready!(self.rx.poll().map_err(|_| BlockingError::Canceled));
|
||||||
|
match res {
|
||||||
|
Ok(val) => Ok(Async::Ready(val)),
|
||||||
|
Err(err) => Err(BlockingError::Error(err)),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,7 @@
|
|||||||
//! A runtime implementation that runs everything on the current thread.
|
//! A runtime implementation that runs everything on the current thread.
|
||||||
|
|
||||||
mod arbiter;
|
mod arbiter;
|
||||||
|
pub mod blocking;
|
||||||
mod builder;
|
mod builder;
|
||||||
mod runtime;
|
mod runtime;
|
||||||
mod system;
|
mod system;
|
||||||
|
Loading…
Reference in New Issue
Block a user