commit
				
					
						649d52e6a1
					
				
			
		
					 3 changed files with 5 additions and 5 deletions
				
			
		|  | @ -27,7 +27,7 @@ thiserror = "1.0.40" | |||
| x509-parser = "0.15.0" | ||||
| derive_builder = "0.12.0" | ||||
| futures = { version = "0.3.28", features = ["alloc", "async-await"] } | ||||
| tokio = { version = "1.28.1", default-features = false, features = [ | ||||
| tokio = { version = "1.28.2", default-features = false, features = [ | ||||
|   "net", | ||||
|   "rt-multi-thread", | ||||
|   "parking_lot", | ||||
|  |  | |||
|  | @ -10,11 +10,11 @@ | |||
| 
 | ||||
| ## Introduction | ||||
| 
 | ||||
| `rpxy` [ahr-pik-see] is an implementation of simple and lightweight reverse-proxy with some additional features. The implementation is based on [`hyper`](https://github.com/hyperium/hyper), [`rustls`](https://github.com/rustls/rustls) and [`tokio`](https://github.com/tokio-rs/tokio), i.e., written in pure Rust. Our `rpxy` allows to route multiple host names to appropriate backend application servers while serving TLS connections. | ||||
| `rpxy` [ahr-pik-see] is an implementation of simple and lightweight reverse-proxy with some additional features. The implementation is based on [`hyper`](https://github.com/hyperium/hyper), [`rustls`](https://github.com/rustls/rustls) and [`tokio`](https://github.com/tokio-rs/tokio), i.e., written in pure Rust. Our `rpxy` routes multiple host names to appropriate backend application servers while serving TLS connections. | ||||
| 
 | ||||
|  As default, `rpxy` provides the *TLS connection sanitization* by correctly binding a certificate used to establish secure channel with backend application. Specifically, it always keeps the consistency between the given SNI (server name indication) in `ClientHello` of the underlying TLS and the domain name given by the overlaid HTTP HOST header (or URL in Request line) [^1]. Additionally, as a somewhat unstable feature, our `rpxy` can handle the brand-new HTTP/3 connection thanks to [`quinn`](https://github.com/quinn-rs/quinn) and [`hyperium/h3`](https://github.com/hyperium/h3). | ||||
|  As default, `rpxy` provides the *TLS connection sanitization* by correctly binding a certificate used to establish a secure channel with the backend application. Specifically, it always keeps the consistency between the given SNI (server name indication) in `ClientHello` of the underlying TLS and the domain name given by the overlaid HTTP HOST header (or URL in Request line) [^1]. Additionally, as a somewhat unstable feature, our `rpxy` can handle the brand-new HTTP/3 connection thanks to [`quinn`](https://github.com/quinn-rs/quinn) and [`hyperium/h3`](https://github.com/hyperium/h3). | ||||
| 
 | ||||
|  This project is still *work-in-progress*. But it is already working in some production environments and serves numbers of domain names. Furthermore it *significantly outperforms* NGINX and Caddy, e.g., *1.5x faster than NGINX*, in the setting of very simple HTTP reverse-proxy scenario (See [`bench`](./bench/) directory). | ||||
|  This project is still *work-in-progress*. But it is already working in some production environments and serves a number of domain names. Furthermore it *significantly outperforms* NGINX and Caddy, e.g., *1.5x faster than NGINX*, in the setting of a very simple HTTP reverse-proxy scenario (See [`bench`](./bench/) directory). | ||||
| 
 | ||||
|  [^1]: We should note that NGINX doesn't guarantee such a consistency by default. To this end, you have to add `if` statement in the configuration file in NGINX. | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										2
									
								
								quinn
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								quinn
									
										
									
									
									
								
							|  | @ -1 +1 @@ | |||
| Subproject commit 0c6b743f188b8f1d2c38689ecf6f748d393fbb52 | ||||
| Subproject commit 33e3f1603b763d7d7c3a209f90660f35f49495be | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Jun Kurihara
				Jun Kurihara