Skip to content

A Hyper library allowing HTTP clients over a Unix socket, a Vsock socket and a Firecracker socket

License

Notifications You must be signed in to change notification settings

rust-firecracker/hyper-client-sockets

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Hyper Client Sockets

Before hyper v1, hyperlocal was the most convenient solution to use Unix sockets for both client and server. With hyper v1, server socket support is no longer needed (just use UnixListener or VsockListener instead of TcpListener), yet hyperlocal still has it and hasn't received a release since several years.

This library provides hyper v1 client support for:

  • Unix (AF_UNIX) sockets (HyperUnixStream implementing hyper traits)
  • VSock (AF_VSOCK) sockets (HyperVsockStream implementing hyper traits)
  • Firecracker Unix sockets that need CONNECT commands in order to establish a tunnel (HyperFirecrackerStream implementing hyper traits)

Additionally, the library supports different async I/O backends:

  • Tokio using tokio-backend
  • async-io stack using async-io-backend

The backend to use when connecting can be specified with the Backend trait. Compiling with both backends enabled is supported but not recommended, and leaving the choice of backend to the user is recommended for library developers.

Lastly, the hyper-util feature provides compatibility with hyper-util's Client connection pool via hex-encoded URIs.

About

A Hyper library allowing HTTP clients over a Unix socket, a Vsock socket and a Firecracker socket

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages