You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The maintainers of websockets and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. Learn more.
(If you contribute to websockets and would like to become an official support provider, let me know.)
Why should I use websockets?
The development of websockets is shaped by four principles:
Correctness: websockets is heavily tested for compliance with
RFC 6455. Continuous integration fails under 100% branch coverage.
Simplicity: all you need to understand is msg = await ws.recv() and
await ws.send(msg). websockets takes care of managing connections
so you can focus on your application.
Robustness: websockets is built for production. For example, it was
the only library to handle backpressure correctly before the issue
became widely known in the Python community.
Performance: memory usage is optimized and configurable. A C extension
accelerates expensive operations. It's pre-compiled for Linux, macOS and
Windows and packaged in the wheel format for each system and Python version.
Documentation is a first class concern in the project. Head over to Read the
Docs and see for yourself.
Why shouldn't I use websockets?
If you prefer callbacks over coroutines: websockets was created to
provide the best coroutine-based API to manage WebSocket connections in
Python. Pick another library for a callback-based API.
If you're looking for a mixed HTTP / WebSocket library: websockets aims
at being an excellent implementation of RFC 6455: The WebSocket Protocol
and RFC 7692: Compression Extensions for WebSocket. Its support for HTTP
is minimal — just enough for an HTTP health check.
If you want to do both in the same server, look at HTTP + WebSocket servers
that build on top of websockets to support WebSocket connections, like
uvicorn or Sanic.
What else?
Bug reports, patches and suggestions are welcome!
To report a security vulnerability, please use the Tidelift security
contact. Tidelift will coordinate the fix and disclosure.