Skip to content
This repository has been archived by the owner on Jan 20, 2025. It is now read-only.

Latest commit

 

History

History
25 lines (19 loc) · 812 Bytes

README.md

File metadata and controls

25 lines (19 loc) · 812 Bytes

tcp-proxy

experimental zero-copy tcp-proxy

usage: $ make $ ./bin/tcp-proxy

ex: $ ./bin/tcp-proxy localhost:8080 localhost:8000

Some implementations hints:

  • by default start nproc threads each running independent event loop (libev)
  • each eventloop accepting connection (socket created with SO_REUSEPORT)
  • accepting a connection is malloc-free (occasional reallocations are possible)
  • communication happens between downstream <-> upstream by means of splice()

further possible improvement/tunings:

  • backoff strategy when when reading from a socket
  • pthread CPU/memory affinity
  • IRQ and interface's queue processing affinity
  • add support of SO_LINGER which can be useful to reduce amount of sockets in TAIM_WAIT state after disconnecting from upstream