From 91a6942e49a8e06c0d277fac868641c52f42e167 Mon Sep 17 00:00:00 2001 From: Abhinav Singh Date: Wed, 25 Sep 2019 10:09:40 -0700 Subject: [PATCH] Add starting proxy.py instructions --- README.md | 63 ++++++++++++++++++++++++++++++++++++++++++++++++++----- proxy.py | 2 +- 2 files changed, 59 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index e79c7866..860d165c 100644 --- a/README.md +++ b/README.md @@ -31,7 +31,9 @@ Table of Contents * [Install](#install) * [Stable version](#stable-version) * [Development version](#development-version) - * [Docker](#docker-image) +* [Start proxy.py](#start-proxypy) + * [Command Line](#command-line) + * [Docker Image](#docker-image) * [Plugin Examples](#plugin-examples) * [RedirectToCustomServerPlugin](#redirecttocustomserverplugin) * [FilterByUpstreamHostPlugin](#filterbyupstreamhostplugin) @@ -77,19 +79,70 @@ Features Install ======= -#### Stable version +## Stable version $ pip install --upgrade proxy.py -#### Development version +## Development version $ pip install git+https://github.com/abhinavsingh/proxy.py.git@develop -#### Docker image +For `Docker` usage see [Docker Image](#docker-image). + +Start proxy.py +============== + +## Command line + +Simply type `proxy.py` on command line to start it with default configuration. + +``` +$ proxy.py +...[redacted]... - Loaded plugin +...[redacted]... - Starting 8 workers +...[redacted]... - Started server on ::1:8899 +``` + +Things to notice from above logs: + +- `Loaded plugin` - `proxy.py` will load `HttpProxyPlugin` by default. It adds `http(s)` + proxy server capabilities to `proxy.py` + +- `Started N workers` - Use `--num-workers` flag to customize number of `Worker` processes. + By default, `proxy.py` will start as many workers as there are CPU cores on the machine. + +- `Started server on ::1:8899` - By default, `proxy.py` listens on IPv6 `::1`, which + is equivalent of IPv4 `127.0.0.1`. If you want to access `proxy.py` externally, + use `--hostname ::` or `--hostname 0.0.0.0` or bind to any other interface available + on your machine. + +- `Port 8899` - Use `--port` flag to customize default TCP port. + +All the logs above are `INFO` level logs, default `--log-level` for `proxy.py`. + +Lets start `proxy.py` with `DEBUG` level logging: + +``` +$ proxy.py --log-level d +...[redacted]... - Open file descriptor soft limit set to 1024 +...[redacted]... - Loaded plugin +...[redacted]... - Started 8 workers +...[redacted]... - Started server on ::1:8899 +``` + +As we can see, before starting up: + +- `proxy.py` also tried to set open file limit `ulimit` on the system. +- Default value for `--open-file-limit` used is `1024`. +- `--open-file-limit` flag is a no-op on `Windows` operating systems. + +See [flags](#flags) for full list of available configuration options. + +## Docker image $ docker run -it -p 8899:8899 --rm abhinavsingh/proxy.py:v1.0.0 -By default `docker` binary is started with following flags: +By default `docker` binary is started with IPv4 networking flags: --hostname 0.0.0.0 --port 8899 diff --git a/proxy.py b/proxy.py index 72a8c7a1..b0858bb2 100755 --- a/proxy.py +++ b/proxy.py @@ -386,7 +386,6 @@ class MultiCoreRequestDispatcher(TcpServer): self.config: HttpProtocolConfig = config def setup(self) -> None: - logger.info('Starting %d workers' % self.config.num_workers) for worker_id in range(self.config.num_workers): work_queue = multiprocessing.Pipe() @@ -396,6 +395,7 @@ class MultiCoreRequestDispatcher(TcpServer): self.workers.append(worker) self.work_queues.append(work_queue) + logger.info('Started %d workers' % self.config.num_workers) def handle(self, client: TcpClientConnection) -> None: # Dispatch in round robin fashion