A clean-room ASGI server with Uvicorn-compatible CLI and behavior mapping.
Project description
Palfrey
Palfrey is a clean-room, high-performance Python ASGI server with source-traceable parity mapping.
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.
- accepts TCP or UNIX socket connections
- parses protocol bytes into ASGI events
- calls your app with
scope,receive,send - writes responses back to clients
- manages process behavior (reload, workers, graceful shutdown)
Who Should Start Where
If you are new to ASGI
If you operate production services
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5d5d1df0532ada8fa0bee313400f4c52c56b2dd7844fecb8612c826559258488
|
|
| MD5 |
808fe06cfa289b093a667b1eec459028
|
|
| BLAKE2b-256 |
7f5875fddab73d40eebd4d1a0d3887684eb94968bbdf7cfa645a03f114d0fcb0
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
516930c1d62af7d55151c4e58915b35a3fab6cbd7a6aca50e5dec62cfea80835
|
|
| MD5 |
efc93e1362bfbd0eb8554e12cd83ad3d
|
|
| BLAKE2b-256 |
0168cc851efa54e3066ddb218441b54a1364dffc28fdca767560dc95f2d7008e
|