# tokio-global
[](https://gitlab.com/Douman/tokio-global/pipelines)
[](https://crates.io/crates/tokio-global)
[](https://docs.rs/crate/tokio-global/)
Simple way to create global tokio runtime, available from any place in code
## Usage
Start runtime and use `AutoRuntime` trait to spawn your futures:
```rust
use tokio_global::{Runtime, AutoRuntime};
use tokio::io::{AsyncWriteExt, AsyncReadExt};
async fn server() {
let mut listener = tokio::net::TcpListener::bind("127.0.0.1:8080").await.expect("To bind");
let (mut socket, _) = listener.accept().await.expect("To accept connection");
async move {
let mut buf = [0; 1024];
loop {
match socket.read(&mut buf).await {
// socket closed
Ok(0) => return,
Ok(_) => continue,
Err(_) => panic!("Error :("),
};
}
}.spawn().await.expect("Finish listening");
}
async fn client() {
let mut stream = tokio::net::TcpStream::connect("127.0.0.1:8080").await.expect("Connect");
// Write some data.
stream.write_all(b"hello world!").await.expect("Write");
//Stop runtime
Runtime::stop();
}
let _guard = Runtime::default();
});
server().spawn();
client().spawn();
```