async-io/README.md

79 lines
2.7 KiB
Markdown
Raw Permalink Normal View History

2020-06-29 14:27:19 +00:00
# async-io
2020-06-29 14:26:06 +00:00
2020-06-29 14:27:19 +00:00
[![Build](https://github.com/stjepang/async-io/workflows/Build%20and%20test/badge.svg)](
https://github.com/stjepang/async-io/actions)
2020-06-29 14:26:06 +00:00
[![License](https://img.shields.io/badge/license-MIT%2FApache--2.0-blue.svg)](
2020-06-29 14:27:19 +00:00
https://github.com/stjepang/async-io)
[![Cargo](https://img.shields.io/crates/v/async-io.svg)](
https://crates.io/crates/async-io)
[![Documentation](https://docs.rs/async-io/badge.svg)](
https://docs.rs/async-io)
2020-06-29 14:26:06 +00:00
2020-07-31 15:05:52 +00:00
Async I/O and timers.
This crate provides two tools:
* `Async`, an adapter for standard networking types (and [many other] types) to use in
async programs.
2020-08-12 15:50:26 +00:00
* `Timer`, a future that expires at a point in time.
2020-07-31 15:05:52 +00:00
For concrete async networking types built on top of this crate, see [`async-net`].
[many other]: https://github.com/stjepang/async-io/tree/master/examples
[`async-net`]: https://docs.rs/async-net
## Implementation
The first time `Async` or `Timer` is used, a thread named "async-io" will be spawned.
The purpose of this thread is to wait for I/O events reported by the operating system, and then
wake appropriate futures blocked on I/O or timers when they can be resumed.
To wait for the next I/O event, the "async-io" thread uses [epoll] on Linux/Android/illumos,
2020-08-12 15:50:26 +00:00
[kqueue] on macOS/iOS/BSD, [event ports] on illumos/Solaris, and [wepoll] on Windows. That
functionality is provided by the [`polling`] crate.
2020-07-31 15:05:52 +00:00
2020-08-26 21:36:58 +00:00
However, note that you can also process I/O events and wake futures on any thread using the
`block_on()` function. The "async-io" thread is therefore just a fallback mechanism
processing I/O events in case no other threads are.
2020-07-31 15:05:52 +00:00
[epoll]: https://en.wikipedia.org/wiki/Epoll
[kqueue]: https://en.wikipedia.org/wiki/Kqueue
2020-08-12 12:28:19 +00:00
[event ports]: https://illumos.org/man/port_create
2020-07-31 15:05:52 +00:00
[wepoll]: https://github.com/piscisaureus/wepoll
2020-08-12 15:50:26 +00:00
[`polling`]: https://docs.rs/polling
2020-07-31 15:05:52 +00:00
## Examples
Connect to `example.com:80`, or time out after 10 seconds.
```rust
use async_io::{Async, Timer};
use futures_lite::{future::FutureExt, io};
use std::net::{TcpStream, ToSocketAddrs};
use std::time::Duration;
let addr = "example.com:80".to_socket_addrs()?.next().unwrap();
let stream = Async::<TcpStream>::connect(addr).or(async {
2020-08-12 15:50:26 +00:00
Timer::after(Duration::from_secs(10)).await;
2020-07-31 15:05:52 +00:00
Err(io::ErrorKind::TimedOut.into())
})
.await?;
```
2020-06-29 14:26:06 +00:00
## License
Licensed under either of
* Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
at your option.
#### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.