proxy.py is made with performance in mind. By default, proxy.py will try to utilize all available CPU cores to it for accepting new client connections. This is achieved by starting AcceptorPool which listens on configured server port. Then, AcceptorPool starts Acceptor processes (--num-acceptors) to accept incoming client connections. Alongside, if --threadless is enabled, ThreadlessPool is setup which starts Threadless processes (--num-workers) to handle the incoming client connections. Each Acceptor process delegates the accepted client connection to a threadless process via Work class. Currently, HttpProtocolHandler is the default work class. HttpProtocolHandler simply assumes that incoming clients will follow HTTP specification. Specific HTTP proxy and HTTP server implementations are written as plugins of HttpProtocolHandler.

Features

  • Fast & Scalable
  • Scale up by using all available cores on the system
  • Threadless executions using asyncio
  • Made to handle tens-of-thousands connections / sec
  • Customize proxy behavior using Proxy Server Plugins
  • Plugin API is currently in development phase

Project Samples

Project Activity

See All Activity >

License

BSD License

Follow proxy.py

proxy.py Web Site

Other Useful Business Software
Secure File Transfer for Windows with Cerberus by Redwood Icon
Secure File Transfer for Windows with Cerberus by Redwood

Protect and share files over FTP/S, SFTP, HTTPS and SCP with the #1 rated Windows file transfer server.

Cerberus supports unlimited users and connections on a single IP, with built-in encryption, 2FA, and a browser-based web client — all deployable in under 15 minutes with a 25-day free trial.
Try for Free
Rate This Project
Login To Rate This Project

User Reviews

Be the first to post a review of proxy.py!

Additional Project Details

Programming Language

Python

Related Categories

Python Proxy Servers, Python MiTM (Man-in-The-Middle) Attack Tool

Registered

2023-08-14