tokio udt
v0.1.0-alpha.8
Реализация протокола передачи данных (UDT) на основе UDP на основе примитивов Tokio.
UDT — это высокопроизводительный протокол передачи данных. Он был разработан специально для приложений с интенсивным использованием данных в высокоскоростных глобальных сетях, чтобы преодолеть проблемы эффективности и справедливости TCP. Как видно из названия, UDT построен на основе UDP и обеспечивает как надежные услуги потоковой передачи данных, так и службы обмена сообщениями.
Чтобы узнать больше о UDT, см. https://udt.sourceforge.io/.
Вы также можете найти эталонную реализацию C++ на https://github.com/eminence/udt.
use std :: net :: Ipv4Addr ;
use tokio :: io :: { AsyncReadExt , Result } ;
use tokio_udt :: UdtListener ;
# [ tokio :: main ]
async fn main ( ) -> Result < ( ) > {
let port = 9000 ;
let listener = UdtListener :: bind ( ( Ipv4Addr :: UNSPECIFIED , port ) . into ( ) , None ) . await ? ;
println ! ( "Waiting for connections..." ) ;
loop {
let ( addr , mut connection ) = listener . accept ( ) . await ? ;
println ! ( "Accepted connection from {}" , addr ) ;
let mut buffer = Vec :: with_capacity ( 1_000_000 ) ;
tokio :: task :: spawn ( {
async move {
loop {
match connection . read_buf ( & mut buffer ) . await {
Ok ( _size ) => { }
Err ( e ) => {
eprintln ! ( "Connnection with {} failed: {}" , addr , e ) ;
break ;
}
}
}
}
} ) ;
}
} use std :: net :: Ipv4Addr ;
use tokio :: io :: { AsyncWriteExt , Result } ;
use tokio_udt :: UdtConnection ;
# [ tokio :: main ]
async fn main ( ) -> Result < ( ) > {
let port = 9000 ;
let mut connection = UdtConnection :: connect ( ( Ipv4Addr :: LOCALHOST , port ) , None ) . await ? ;
loop {
connection . write_all ( b"Hello World!" ) . await ? ;
}
}