- Drop ASGI spec version to 2.3 on HTTP scope #2513
- Enable httptools lenient data on
httptools >= 0.6.3
#2488
- Officially support Python 3.13 (#2482)
- Warn when
max_request_limit
is exceeded (#2430)
- Support WebSockets 0.13.1 (#2471)
- Restore support for
[*]
in trusted hosts (#2480) - Add
PathLike[str]
type hint forssl_keyfile
(#2481)
Improve ProxyHeadersMiddleware
(#2468) and (#2231):
- Fix the host for requests from clients running on the proxy server itself.
- Fallback to host that was already set for empty x-forwarded-for headers.
- Also allow to specify IP Networks as trusted hosts. This greatly simplifies deployments
on docker swarm/kubernetes, where the reverse proxy might have a dynamic IP.
- This includes support for IPv6 Address/Networks.
- Don't warn when upgrade is not WebSocket and depedencies are installed (#2360)
- Don't close connection before receiving body on H11 (#2408)
- Close connection when
h11
sets client state toMUST_CLOSE
(#2375)
- Suppress
KeyboardInterrupt
from CLI and programmatic usage (#2384) ClientDisconnect
inherits fromOSError
instead ofIOError
(#2393)
- Add
reason
support towebsocket.disconnect
event (#2324)
- Iterate subprocesses in-place on the process manager (#2373)
- Allow horizontal tabs
\t
in response header values (#2345)
- New multiprocess manager (#2183)
- Allow
ConfigParser
or aio.IO[Any]
onlog_config
(#1976)
- Suppress side-effects of signal propagation (#2317)
- Send
content-length
header on 5xx (#2304)
- Deprecate the
uvicorn.workers
module (#2302)
- Cooperative signal handling (#1600)
- Revert raise
ClientDisconnected
on HTTP (#2276)
- Raise
ClientDisconnected
onsend()
when client disconnected (#2220)
- Except
AttributeError
onsys.stdin.fileno()
for Windows IIS10 (#1947) - Use
X-Forwarded-Proto
for WebSockets scheme when the proxy provides it (#2258)
- Fix spurious LocalProtocolError errors when processing pipelined requests (#2243)
- Fix nav overrides for newer version of Mkdocs Material (#2233)
- Raise
ClientDisconnect(IOError)
onsend()
when client disconnected (#2218) - Bump ASGI WebSocket spec version to 2.4 (#2221)
- Update
--root-path
to include the root path prefix in the full ASGIpath
as per the ASGI spec (#2213) - Use
__future__.annotations
on some internal modules (#2199)
- Support the WebSocket Denial Response ASGI extension (#1916)
- Allow explicit hidden file paths on
--reload-include
(#2176) - Properly annotate
uvicorn.run()
(#2158)
- Revert mkdocs-material from 9.1.21 to 9.2.6 (#2148)
- Support Python 3.12 (#2145)
- Allow setting
app
via environment variableUVICORN_APP
(#2106)
- Maintain the same behavior of
websockets
from 10.4 on 11.0 (#2061)
- Add
typing_extensions
for Python 3.10 and lower (#2053)
- Add
--ws-max-queue
parameter WebSockets (#2033)
- Drop support for Python 3.7 (#1996)
- Remove
asgiref
as typing dependency (#1999)
- Set
scope["scheme"]
tows
orwss
instead ofhttp
orhttps
onProxyHeadersMiddleware
for WebSockets (#2043)
- Raise
ImportError
on circular import (#2040) - Use
logger.getEffectiveLevel()
instead oflogger.level
to check if log level isTRACE
(#1966)
- Add
--timeout-graceful-shutdown
parameter (#1950) - Handle
SIGBREAK
on Windows (#1909)
- Shutdown event is now being triggered on Windows when using hot reload (#1584)
--reload-delay
is effectively used on thewatchfiles
reloader (#1930)
- Reset lifespan state on each request (#1903)
- Introduce lifespan state (#1818)
- Allow headers to be sent as iterables on H11 implementation (#1782)
- Improve discoverability when --port=0 is used (#1890)
- Avoid importing
h11
andpyyaml
when not needed to improve import time (#1846) - Replace current native
WSGIMiddleware
implementation bya2wsgi
(#1825) - Change default
--app-dir
from "." (dot) to "" (empty string) (#1835)
- Send code 1012 on shutdown for WebSockets (#1816)
- Use
surrogateescape
to encode headers onwebsockets
implementation (#1005) - Fix warning message on reload failure (#1784)
- Check if handshake is completed before sending frame on
wsproto
shutdown (#1737) - Add default headers to WebSockets implementations (#1606 & #1747)
- Warn user when
reload
andworkers
flag are used together (#1731)
- Use correct
WebSocket
error codes onclose
(#1753) - Send disconnect event on connection lost for
wsproto
(#996) - Add
SIGQUIT
handler toUvicornWorker
(#1710) - Fix crash on exist with "--uds" if socket doesn't exist (#1725)
- Annotate
CONFIG_KWARGS
inUvicornWorker
class (#1746)
- Remove conditional on
RemoteProtocolError.event_hint
onwsproto
(#1486) - Remove unused
handle_no_connect
onwsproto
implementation (#1759)
- Support Python 3.11 (#1652)
- Bump minimal
httptools
version to0.5.0
(#1645) - Ignore HTTP/2 upgrade and optionally ignore WebSocket upgrade (#1661)
- Add
py.typed
to comply with PEP 561 (#1687)
- Set
propagate
toFalse
on "uvicorn" logger (#1288) - USR1 signal is now handled correctly on
UvicornWorker
. (#1565) - Use path with query string on
WebSockets
logs (#1385) - Fix behavior on which "Date" headers were not updated on the same connection (#1706)
- Remove the
--debug
flag (#1640) - Remove the
DebugMiddleware
(#1697)
- Remove cyclic references on HTTP implementations. (#1604)
reload_delay
default changed fromNone
to0.25
onuvicorn.run()
andConfig
.None
is not an acceptable value anymore. (#1545)
- Add default
log_config
onuvicorn.run()
(#1541) - Revert
logging
file name modification (#1543)
- Use
DEFAULT_MAX_INCOMPLETE_EVENT_SIZE
as default toh11_max_incomplete_event_size
on the CLI (#1534)
- The
reload
flag prioritizeswatchfiles
instead of the deprecatedwatchgod
(#1437) - Annotate
uvicorn.run()
function (#1423) - Allow configuring
max_incomplete_event_size
forh11
implementation (#1514)
- Remove
asgiref
dependency (#1532)
- Turn
raw_path
into bytes on both websockets implementations (#1487) - Revert log exception traceback in case of invalid HTTP request (#1518)
- Set
asyncio.WindowsSelectorEventLoopPolicy()
when using multiple workers to avoid "WinError 87" (#1454)
- Change
httptools
range to>=0.4.0
(#1400)
- Fix case where url is fragmented in httptools protocol (#1263)
- Fix WSGI middleware not to explode quadratically in the case of a larger body (#1329)
- Send HTTP 400 response for invalid request (#1352)
- Replace
create_server
bycreate_unix_server
(#1362)
- Drop wsproto version checking. (#1359)
- Revert #1332. While trying to solve the memory leak, it introduced an issue (#1345) when the server receives big chunks of data using the
httptools
implementation. (#1354) - Revert stream interface changes. This was introduced on 0.14.0, and caused an issue (#1226), which caused a memory leak when sending TCP pings. (#1355)
- Fix wsproto version check expression (#1342)
- Move all data handling logic to protocol and ensure connection is closed. (#1332)
- Change
spec_version
field from "2.1" to "2.3", as Uvicorn is compliant with that version of the ASGI specifications. (#1337)
- Add the
python_requires
version specifier (#1328)
- Allow configurable websocket per-message-deflate setting (#1300)
- Support extra_headers for WS accept message (#1293)
- Add missing http version on websockets scope (#1309)
- Drop Python 3.6 support (#1261)
- Fix reload process behavior when exception is raised (#1313)
- Remove
root_path
from logs (#1294)
- Enable read of uvicorn settings from environment variables (#1279)
- Bump
websockets
to 10.0. (#1180) - Ensure non-zero exit code when startup fails (#1278)
- Increase
httptools
version range from "==0.2.*" to ">=0.2.0,<0.4.0". (#1243) - Override default asyncio event loop with reload only on Windows (#1257)
- Replace
HttpToolsProtocol.pipeline
type fromlist
todeque
. (#1213) - Replace
WSGIResponder.send_queue
type fromlist
todeque
. (#1214)
- Main process exit after startup failure on reloader classes (#1177)
- Add explicit casting on click options (#1217)
- Allow WebSocket close event to receive reason being None from ASGI app. (#1259)
- Fix a bug in
WebSocketProtocol.asgi_receive
on which we returned a close frame even if there were data messages before that frame in the read queue. (#1252) - The option
--reload-dirs
was splitting a string into single character directories. (#1267) - Only second SIGINT is able to forcefully shutdown the server (#1269)
- Allow app-dir parameter on the run() function (#1271)
- Change reload to be configurable with glob patterns. Currently only
.py
files are watched, which is different from the previous default behavior. (#820) - Add Python 3.10-rc.1 support. Now the server uses
asyncio.run
which will: start a fresh asyncio event loop, on shutdown cancel any background tasks rather than aborting them,aexit
any remaining async generators, and shutdown the defaultThreadPoolExecutor
. (#1070) - Exit with status 3 when worker starts failed (#1077)
- Add option to set websocket ping interval and timeout (#1048)
- Adapt bind_socket to make it usable with multiple processes (#1009)
- Add existence check to the reload directory(ies) (#1089)
- Add missing trace log for websocket protocols (#1083)
- Support disabling default Server and Date headers (#818)
- Add PEP440 compliant version of click (#1099)
- Bump asgiref to 3.4.0 (#1100)
- When receiving a
SIGTERM
supervisors now terminate their processes before joining them (#1069) - Fix the need of
httptools
on minimal installation (#1135) - Fix ping parameters annotation in Config class (#1127)
- Defaults ws max_size on server to 16MB (#995)
- Improve user feedback if no ws library installed (#926 and #1023)
- Support 'reason' field in 'websocket.close' messages (#957)
- Implemented lifespan.shutdown.failed (#755)
- Upgraded websockets requirements (#1065)
- Switch to asyncio streams API (#869)
- Update httptools from 0.1.* to 0.2.* (#1024)
- Allow Click 8.0, refs #1016 (#1042)
- Add search for a trusted host in ProxyHeadersMiddleware (#591)
- Up wsproto to 1.0.0 (#892)
- Force reload_dirs to be a list (#978)
- Fix gunicorn worker not running if extras not installed (#901)
- Fix socket port 0 (#975)
- Prevent garbage collection of main lifespan task (#972)
- Fixed wsgi middleware PATH_INFO encoding (#962)
- Fixed uvloop dependency (#952) then (#959)
- Relax watchgod up bound (#946)
- Return 'connection: close' header in response (#721)
- Docs: Nginx + websockets (#948)
- Document the default value of 1 for workers (#940) (#943)
- Enabled permessage-deflate extension in websockets (#764)
- Prevent swallowing of return codes from
subprocess
when running with Gunicorn by properly resetting signals. (#895) - Tweak detection of app factories to be more robust. A warning is now logged when passing a factory without the
--factory
flag. (#914) - Properly clean tasks when handshake is aborted when running with
--ws websockets
. (#921)
- Log full exception traceback in case of invalid HTTP request. (#886 and #888)
- Prevent exceptions when the ASGI application rejects a connection during the WebSocket handshake, when running on both
--ws wsproto
or--ws websockets
. (#704 and #881) - Ensure connection
scope
doesn't leak in logs when using JSON log formatters. (#859 and #884)
- Add
--factory
flag to support factory-style application imports. (#875) - Skip installation of signal handlers when not in the main thread. Allows using
Server
in multithreaded contexts without having to override.install_signal_handlers()
. (#871)
- Fix race condition that leads Quart to hang with uvicorn (#848)
- Use latin1 when decoding X-Forwarded-* headers (#701)
- Rework IPv6 support (#837)
- Cancel old keepalive-trigger before setting new one. (#832)
- Adding ability to decrypt ssl key file (#808)
- Support .yml log config files (#799)
- Added python 3.9 support (#804)
- Fixes watchgod with common prefixes (#817)
- Fix reload with ipv6 host (#803)
- Added cli support for headers containing colon (#813)
- Sharing socket across workers on windows (#802)
- Note the need to configure trusted "ips" when using unix sockets (#796)
- Pinning h11 and python-dotenv to min versions (#789)
- Get docs/index.md in sync with README.md (#784)
- Improve changelog by pointing out breaking changes (#792)
- Make reload delay configurable (#774)
- Upgrade maximum h11 dependency version to 0.10 (#772)
- Allow .json or .yaml --log-config files (#665)
- Add ASGI dict to the lifespan scope (#754)
- Upgrade wsproto to 0.15.0 (#750)
- Use optional package installs (#666)
- Don't set log level for root logger (#767) 8/28/20 df81b168
- Uvicorn no longer ships extra dependencies
uvloop
,websockets
andhttptools
as default. To install these dependencies useuvicorn[standard]
.
- Revert "Improve shutdown robustness when using
--reload
or multiprocessing (#620)" (#756) - Fix terminate error in windows (#744)
- Fix bug where --log-config disables uvicorn loggers (#512)
- Fix a regression that caused Uvicorn to crash when using
--interface=wsgi
. (#730) - Fix a regression that caused Uvicorn to crash when using unix domain sockets. (#729)
- SECURITY FIX: Prevent sending invalid HTTP header names and values. (#725)
- SECURITY FIX: Ensure path value is escaped before logging to the console. (#724)
- Fix
--proxy-headers
client IP and host when using a Unix socket. (#636)
- Fix overriding the root logger.
- Revert "Watch all files, not just .py" due to unexpected side effects.
- Revert "Pass through gunicorn timeout config." due to unexpected side effects.
- Use
watchgod
, if installed, for watching code changes. - Watch all files, not just .py.
- Pass through gunicorn timeout config.
- Update dependencies.
- Don't open socket until after application startup.
- Support
--backlog
.
- Use a more liberal
h11
dependency. Either0.8.*
or `0.9.*``.
- Fix reload/multiprocessing on Windows with Python 3.8.
- Drop IOCP support. (Required for fix above.)
- Add
uvicorn --version
flag. - Add
--use-colors
and--no-use-colors
flags. - Display port correctly, when auto port selection isused with
--port=0
.
- Fix reload/multiprocessing error.
- Use resource_sharer.DupSocket to resolve socket sharing on Windows.
- Exit if
workers
orreload
are use without an app import string style. - Reorganise supervisor processes to properly hand over sockets on windows.
- Update uvloop dependency to 0.14+
- Error clearly when
workers=<NUM>
is used with app instance, instead of an app import string. - Switch
--reload-dir
to current working directory by default.
- Add ``--log-level trace`
- Enable --proxy-headers by default.
- Resolve issues with logging when using
--reload
or--workers
. - Setup up root logger to capture output for all logger instances, not just
uvicorn.error
anduvicorn.access
.
- Support for Python 3.8
- Separated out
uvicorn.error
anduvicorn.access
logs. - Coloured log output when connected to a terminal.
- Dropped
logger=
config setting. - Added
--log-config [FILE]
andlog_config=[str|dict]
. May either be a Python logging config dictionary or the file name of a logging configuration. - Added
--forwarded_allow_ips
andforwarded_allow_ips
. Defaults to the value of the$FORWARDED_ALLOW_IPS
environment variable or "127.0.0.1". The--proxy-headers
flag now defaults toTrue
, but only trusted IPs are used to populate forwarding info. - The
--workers
setting now defaults to the value of the$WEB_CONCURRENCY
environment variable. - Added support for
--env-file
. Requirespython-dotenv
.