Skip to main content

A clean-room ASGI server with Uvicorn-compatible CLI and behavior mapping.

Project description

Palfrey

Palfrey

Palfrey is a clean-room, high-performance Python ASGI server with source-traceable parity mapping.

Test Suite Package version Supported Python versions CodSpeed


Documentation: https://palfrey.dymmond.com 📚

Source Code: https://github.com/dymmond/palfrey

The official supported version is always the latest released.


Palfrey is a clean-room ASGI server focused on three things:

  • behavior you can reason about
  • deployment controls you can operate safely
  • performance you can reproduce and verify

Protocol runtime modes include HTTP/1.1 backends plus opt-in HTTP/2 (--http h2) and HTTP/3 (--http h3) paths.

Palfrey vs Uvicorn

Palfrey was built with deep respect for Uvicorn and the ASGI ecosystem it helped mature. This is not a "winner vs loser" comparison. Uvicorn is an excellent, battle-tested server, and Palfrey intentionally keeps a compatible API/CLI experience so teams coming from Uvicorn feel at home. Our goal is to offer another strong option when teams want different internal architecture and extended runtime capabilities.

Benchmark snapshot (your run):

  • Command: python -m benchmarks.run --http-requests 100000
Scenario Palfrey Ops/s Uvicorn Ops/s Relative Speed
HTTP 36859.67 36357.47 1.014x
WebSocket 38884.53 15317.18 2.539x

These numbers are environment-dependent. Always benchmark with your own app, traffic profile, and infrastructure before making production decisions.

This documentation is written for both technical and non-technical readers.

  • Engineers can use the protocol details, option tables, and runbooks.
  • Product, support, and operations teams can use the plain-language summaries and checklists.

What Palfrey Does

At runtime, Palfrey sits between clients and your ASGI application.

  1. accepts TCP or UNIX socket connections
  2. parses protocol bytes into ASGI events
  3. calls your app with scope, receive, send
  4. writes responses back to clients
  5. manages process behavior (reload, workers, graceful shutdown)

Who Should Start Where

If you are new to ASGI

  1. Installation
  2. Quickstart
  3. Terms and Mental Models
  4. Server Behavior

If you operate production services

  1. Deployment
  2. Workers
  3. Observability
  4. Troubleshooting
  5. Release Process

First 60 Seconds

Create main.py:

async def app(scope, receive, send):
    """Return a plain-text greeting for HTTP requests."""
    if scope["type"] != "http":
        return

    body = b"Hello from Palfrey"
    await send(
        {
            "type": "http.response.start",
            "status": 200,
            "headers": [
                (b"content-type", b"text/plain; charset=utf-8"),
                (b"content-length", str(len(body)).encode("ascii")),
            ],
        }
    )
    await send({"type": "http.response.body", "body": body})

Run Palfrey:

palfrey main:app --host 127.0.0.1 --port 8000

Check it:

curl http://127.0.0.1:8000

Gunicorn + Palfrey worker:

gunicorn main:app -k palfrey.workers.PalfreyWorker -w 4 -b 0.0.0.0:8000

Documentation Structure

Getting Started

  • install, verify, and run your first app
  • move from a minimal app to real startup patterns

Concepts

  • what ASGI is, and how Palfrey applies it
  • how HTTP, WebSocket, and lifespan flows behave
  • how server internals affect user-visible outcomes

Reference

  • full CLI and config surface
  • protocol and logging behavior
  • env var model and common errors

Guides

  • migration, security hardening, production rollout
  • practical troubleshooting and FAQ

Operations

  • deployment shapes, workers, reload model
  • capacity planning, observability, benchmark method
  • platform-specific notes and release process

Plain-Language Summary

If your application is the business logic, Palfrey is the runtime control layer around it. A good runtime control layer gives teams:

  • predictable startup and shutdown
  • fewer surprises under traffic spikes
  • clearer incident response paths
  • safer, repeatable deployments

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

palfrey-0.1.3.tar.gz (213.0 kB view details)

Uploaded Source

Built Distribution

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

palfrey-0.1.3-py3-none-any.whl (102.6 kB view details)

Uploaded Python 3

File details

Details for the file palfrey-0.1.3.tar.gz.

File metadata

  • Download URL: palfrey-0.1.3.tar.gz
  • Upload date:
  • Size: 213.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.4 cpython/3.10.19 HTTPX/0.28.1

File hashes

Hashes for palfrey-0.1.3.tar.gz
Algorithm Hash digest
SHA256 5d5d1df0532ada8fa0bee313400f4c52c56b2dd7844fecb8612c826559258488
MD5 808fe06cfa289b093a667b1eec459028
BLAKE2b-256 7f5875fddab73d40eebd4d1a0d3887684eb94968bbdf7cfa645a03f114d0fcb0

See more details on using hashes here.

File details

Details for the file palfrey-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: palfrey-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 102.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.4 cpython/3.10.19 HTTPX/0.28.1

File hashes

Hashes for palfrey-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 516930c1d62af7d55151c4e58915b35a3fab6cbd7a6aca50e5dec62cfea80835
MD5 efc93e1362bfbd0eb8554e12cd83ad3d
BLAKE2b-256 0168cc851efa54e3066ddb218441b54a1364dffc28fdca767560dc95f2d7008e

See more details on using hashes here.

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