Skip to main content

A robust, streaming-capable reverse proxy for FastAPI including WebSocket support.

Project description

FastAPI Reverse Proxy

A robust, streaming-capable reverse proxy for FastAPI/Starlette with built-in Latency-Based Load Balancing and Active Health Monitoring.

Features

  • Async: Async by default.
  • Httpx Pool: Async HTTPX Pool for proxying.
  • Streaming Ready: Handles SSE (Server-Sent Events) and large payloads (such as big files) while keeping RAM usage low.
  • WebSocket Support: Seamless bidirectional tunneling with automated subprotocol negotiation.
  • Unified Load Balancing: Standard Round-Robin or Smart routing using a single utility.
  • Latency-Based Routing: Automatically routes traffic to the fastest healthy server (HEAD probe).
  • Advanced Overrides: Granular control over headers, body, and HTTP methods.
  • Version Agnostic: Automatically handles websockets library version differences (12.0+ vs Legacy).

Quick Start

Use the lifespan handler as shown for an easy launch.

The simplest way to use the proxy is to use proxy_pass and/or proxy_pass_websocket on the endpoints.

from fastapi import FastAPI, Request, WebSocket
from contextlib import asynccontextmanager

from fastapi_reverse_proxy import Proxy, proxy_pass, proxy_pass_websocket

@asynccontextmanager
async def lifespan(app: FastAPI):
    async with Proxy(app):
        yield

app = FastAPI(lifespan=lifespan)

# catch-all route. recommended for a reverse proxy
@app.api_route("/{path:path}", methods=["GET","POST","PUT","DELETE"]) # don't forget to add the methods.
async def index(req: Request):
    """
    You always need to pass the "Request" object and to specify the host
    If you don't add a path, it will be the same as the original (/login --> http://127.0.0.1/login)
    """
    return await proxy_pass(req, "http://127.0.0.1:8080")

Advanced Examples:

Check example.py for full examples, including

  • Websocket Proxy
  • Socket.IO Proxy

Advanced Proxying

The proxy_pass function and LoadBalancer.proxy_pass provide deep customization for upstream requests:

Parameter Type Description
method str Force a specific HTTP method (e.g., "POST").
override_body bytes Send custom data instead of the incoming request body.
additional_headers dict Append custom headers to the proxied request.
override_headers dict Use these headers instead of original request headers.
forward_query bool Whether to append the incoming query string (Default: True).

Monitoring & Configuration

HealthChecker (The Loop Owner)

The proactive component. It owns an internal asyncio background task that monitors backends.

  • Immediate Start: When you enter the async with block (or call start()), the checker performs an immediate check of all backends. This eliminates the "cold-start" window where backends are unknown.
  • Configuration Modes:
    • Standard: HealthChecker(["http://a", "http://b"], ping_path="/health")
    • Personalized: Pass a list of dictionaries for per-host settings:
      checker = HealthChecker([
          {"host": "http://api-1", "pingpath": "/v1/status", "maxrequests": 100},
          {"host": "http://api-2", "pingpath": "/health"}
      ])
      
  • Properties:
    • ping_path: Get or set the global health check path (default: "/").

LoadBalancer (The Decision Utility)

A normal Python object that makes routing decisions based on its source.

  • Stateful: While it has no background loop, it does track state (request counts for rate-limiting and the last time it pulled data from the health checker).
  • No Lifecycle Needed: It relies on the HealthChecker (or a static list) for data and doesn't need explicit start/stop calls.

WebSocket Refinements

The library implements "deferred negotiation" for WebSockets:

  1. The proxy receives the client's supported subprotocols from scope.
  2. It establishes an upstream connection first.
  3. Once the upstream accepts a protocol, the proxy calls websocket.accept(subprotocol=...) back to the client.
  4. This ensures the entire tunnel (Client <-> Proxy <-> Upstream) uses the same negotiated protocol.

Robustness & Safety

  • Termination Safety: Resource cleanup (closing httpx clients and sockets) is triggered even on task cancellation (BaseException).
  • Introspection-Based Compatibility: Uses inspect.signature to automatically detect version-specific parameters in the websockets library.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fastapi_reverse_proxy-0.2.0.tar.gz (13.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fastapi_reverse_proxy-0.2.0-py3-none-any.whl (12.8 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_reverse_proxy-0.2.0.tar.gz.

File metadata

  • Download URL: fastapi_reverse_proxy-0.2.0.tar.gz
  • Upload date:
  • Size: 13.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for fastapi_reverse_proxy-0.2.0.tar.gz
Algorithm Hash digest
SHA256 7f6662c497cf589fe121fce3573a8ae04016bd50ae568009e7046cfe9678ee25
MD5 5557b69087a832f6c13908c51d964157
BLAKE2b-256 39238e6d5a7e653bec67a5fd898b687659001002600bbd58cb91989c1ab06ad0

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_reverse_proxy-0.2.0.tar.gz:

Publisher: python-publish.yml on tfsantos05/fastapi-reverse-proxy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fastapi_reverse_proxy-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for fastapi_reverse_proxy-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 228f236fc114f6e18c7eb76cad23c2199dea6d4eec5cb306d4b36b8018e313cf
MD5 4da833acdde612256c35a807eaa744b5
BLAKE2b-256 21a180fe0d30b9d9469e53f13b2994a430f9e8c6269135170b0587d43fad9775

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_reverse_proxy-0.2.0-py3-none-any.whl:

Publisher: python-publish.yml on tfsantos05/fastapi-reverse-proxy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page