mirror of
https://github.com/tokio-rs/tokio.git
synced 2025-09-25 12:00:35 +00:00
113 lines
2.8 KiB
Rust
113 lines
2.8 KiB
Rust
#![cfg(unix)]
|
|
|
|
use tokio_stream::StreamExt;
|
|
|
|
use tokio::fs::File;
|
|
use tokio::io::AsyncReadExt;
|
|
use tokio_util::codec::{BytesCodec, FramedRead /*FramedWrite*/};
|
|
|
|
use criterion::{criterion_group, criterion_main, Criterion};
|
|
|
|
use std::fs::File as StdFile;
|
|
use std::io::Read as StdRead;
|
|
|
|
fn rt() -> tokio::runtime::Runtime {
|
|
tokio::runtime::Builder::new_multi_thread()
|
|
.worker_threads(2)
|
|
.build()
|
|
.unwrap()
|
|
}
|
|
|
|
const BLOCK_COUNT: usize = 1_000;
|
|
|
|
const BUFFER_SIZE: usize = 4096;
|
|
const DEV_ZERO: &str = "/dev/zero";
|
|
|
|
fn async_read_codec(c: &mut Criterion) {
|
|
let rt = rt();
|
|
|
|
c.bench_function("async_read_codec", |b| {
|
|
b.iter(|| {
|
|
let task = || async {
|
|
let file = File::open(DEV_ZERO).await.unwrap();
|
|
let mut input_stream =
|
|
FramedRead::with_capacity(file, BytesCodec::new(), BUFFER_SIZE);
|
|
|
|
for _i in 0..BLOCK_COUNT {
|
|
let _bytes = input_stream.next().await.unwrap();
|
|
}
|
|
};
|
|
|
|
rt.block_on(task());
|
|
})
|
|
});
|
|
}
|
|
|
|
fn async_read_buf(c: &mut Criterion) {
|
|
let rt = rt();
|
|
|
|
c.bench_function("async_read_buf", |b| {
|
|
b.iter(|| {
|
|
let task = || async {
|
|
let mut file = File::open(DEV_ZERO).await.unwrap();
|
|
let mut buffer = [0u8; BUFFER_SIZE];
|
|
|
|
for _i in 0..BLOCK_COUNT {
|
|
let count = file.read(&mut buffer).await.unwrap();
|
|
if count == 0 {
|
|
break;
|
|
}
|
|
}
|
|
};
|
|
|
|
rt.block_on(task());
|
|
});
|
|
});
|
|
}
|
|
|
|
fn async_read_std_file(c: &mut Criterion) {
|
|
let rt = rt();
|
|
|
|
c.bench_function("async_read_std_file", |b| {
|
|
b.iter(|| {
|
|
let task = || async {
|
|
let mut file =
|
|
tokio::task::block_in_place(|| Box::pin(StdFile::open(DEV_ZERO).unwrap()));
|
|
|
|
for _i in 0..BLOCK_COUNT {
|
|
let mut buffer = [0u8; BUFFER_SIZE];
|
|
let mut file_ref = file.as_mut();
|
|
|
|
tokio::task::block_in_place(move || {
|
|
file_ref.read_exact(&mut buffer).unwrap();
|
|
});
|
|
}
|
|
};
|
|
|
|
rt.block_on(task());
|
|
});
|
|
});
|
|
}
|
|
|
|
fn sync_read(c: &mut Criterion) {
|
|
c.bench_function("sync_read", |b| {
|
|
b.iter(|| {
|
|
let mut file = StdFile::open(DEV_ZERO).unwrap();
|
|
let mut buffer = [0u8; BUFFER_SIZE];
|
|
|
|
for _i in 0..BLOCK_COUNT {
|
|
file.read_exact(&mut buffer).unwrap();
|
|
}
|
|
})
|
|
});
|
|
}
|
|
|
|
criterion_group!(
|
|
file,
|
|
async_read_std_file,
|
|
async_read_buf,
|
|
async_read_codec,
|
|
sync_read
|
|
);
|
|
criterion_main!(file);
|