| .github | ||
| bench | ||
| docker-bin | ||
| src | ||
| .dockerignore | ||
| .gitignore | ||
| Cargo.toml | ||
| config-example.toml | ||
| docker-compose.yml | ||
| Dockerfile | ||
| LICENSE | ||
| localhost.crt | ||
| localhost.key | ||
| README.md | ||
| TODO.md | ||
rpxy: A simple and ultrafast reverse-proxy for multiple host names with TLS termination, written in pure Rust
WIP Project
Introduction
rpxy [ahr-pik-see] is an (currently experimental) implementation of simple and lightweight reverse-proxy, which is based on hyper, rustls and tokio, i.e., written in pure Rust. Our rpxy allows to route multiple host names to appropriate backend application servers while serving TLS connections.
This project is still work-in-progress. But it is already working in some production environments and serves numbers of domain names. Furthermore it dramatically outperforms NGINX and Caddy in the setting of very simple HTTP reverse-proxy scenario (See bench directory).
rpxy provides the sanitization of TLS's SNI (server name indication) in default by correctly binding a certificate used to establish an underlying TLS connection with backend application specified in the overlaid HTTP HOST header (or URL in Request line). Additionally, as a somewhat unstable feature, our rpxy can handle the brand-new HTTP/3 connection thanks to quinn and hyperium/h3.
Making an executable binary
% cargo build --release
Then you have a binary at ./target/release/rpxy.
You can also use docker image instead of building from the source.
Usage
todo!
Configuration
todo!
Using docker image
todo!
