Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Managed TCP streams #37

Merged
merged 46 commits into from
Nov 13, 2024
Merged

Managed TCP streams #37

merged 46 commits into from
Nov 13, 2024

Conversation

OlofBlomqvist
Copy link
Owner

@OlofBlomqvist OlofBlomqvist commented Oct 21, 2024

Rewriting the proxy feature so that we always terminate tls but do not need to terminate http in most cases.
this should dramatically improve performance for cases where tcp tunnel mode is not used.

This pr also adds the ground work for allowing us to capture statistics of in-progress http sessions so that it can be exposed to the web-ui for real-time monitoring of active requests (as in, view normal req/res, websocket messages, http2 streams and so on)

TODO

  • Perf: should stay around 170-200k rps for caddy example
  • LE still working for all types of sites
  • Make sure statistics page works with new mode
  • Support tcp tunnel, tls-termination-only (fancy-mode), and tls+http termination (terminating proxy mode)
  • Connections page should display the three modes
  • Distinguish between the old (unmanaged) tcp tunnel mode and this mode - naming?
  • Error handling - no unwraps etc.
  • Handle all todo's in the changed code

@OlofBlomqvist OlofBlomqvist self-assigned this Oct 21, 2024
@OlofBlomqvist OlofBlomqvist added this to the 0.2.0 milestone Oct 21, 2024
@OlofBlomqvist OlofBlomqvist marked this pull request as ready for review November 13, 2024 22:41
@OlofBlomqvist OlofBlomqvist changed the title [WIP] Managed TCP streams Managed TCP streams Nov 13, 2024
@OlofBlomqvist OlofBlomqvist merged commit a4d117b into main Nov 13, 2024
1 check passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Support for changing port at runtime Re-write TCP peek and tunnel logic
1 participant