Skip to main content

A friendly Python library for async concurrency and I/O

Project description

Join chatroom Join forum Documentation Latest PyPi version Latest conda-forge version Test coverage

Trio – a friendly Python library for async concurrency and I/O

https://raw.githubusercontent.com/python-trio/trio/9b0bec646a31e0d0f67b8b6ecc6939726faf3e17/logo/logo-with-background.svg

The Trio project aims to produce a production-quality, permissively licensed, async/await-native I/O library for Python. Like all async libraries, its main purpose is to help you write programs that do multiple things at the same time with parallelized I/O. A web spider that wants to fetch lots of pages in parallel, a web server that needs to juggle lots of downloads and websocket connections simultaneously, a process supervisor monitoring multiple subprocesses… that sort of thing. Compared to other libraries, Trio attempts to distinguish itself with an obsessive focus on usability and correctness. Concurrency is complicated; we try to make it easy to get things right.

Trio was built from the ground up to take advantage of the latest Python features, and draws inspiration from many sources, in particular Dave Beazley’s Curio. The resulting design is radically simpler than older competitors like asyncio and Twisted, yet just as capable. Trio is the Python I/O library I always wanted; I find it makes building I/O-oriented programs easier, less error-prone, and just plain more fun. Perhaps you’ll find the same.

Trio is a mature and well-tested project: the overall design is solid, and the existing features are fully documented and widely used in production. While we occasionally make minor interface adjustments, breaking changes are rare. We encourage you to use Trio with confidence, but if you rely on long-term API stability, consider subscribing to issue #1 for advance notice of any compatibility updates.

Where to next?

I want to try it out! Awesome! We have a friendly tutorial to get you started; no prior experience with async coding is required.

Ugh, I don’t want to read all that – show me some code! If you’re impatient, then here’s a simple concurrency example, an echo client, and an echo server.

How does Trio make programs easier to read and reason about than competing approaches? Trio is based on a new way of thinking that we call “structured concurrency”. The best theoretical introduction is the article Notes on structured concurrency, or: Go statement considered harmful. Or, check out this talk at PyCon 2018 to see a demonstration of implementing the “Happy Eyeballs” algorithm in an older library versus Trio.

Cool, but will it work on my system? Probably! As long as you have some kind of Python 3.10-or-better (CPython or currently maintained versions of PyPy3 are both fine), and are using Linux, macOS, Windows, or FreeBSD, then Trio will work. Other environments might work too, but those are the ones we test on. And all of our dependencies are pure Python, except for CFFI on Windows, which has wheels available, so installation should be easy (no C compiler needed).

I tried it, but it’s not working. Sorry to hear that! You can try asking for help in our chat room or forum, filing a bug, or posting a question on StackOverflow, and we’ll do our best to help you out.

Trio is awesome, and I want to help make it more awesome! You’re the best! There’s tons of work to do – filling in missing functionality, building up an ecosystem of Trio-using libraries, usability testing (e.g., maybe try teaching yourself or a friend to use Trio and make a list of every error message you hit and place where you got confused?), improving the docs, … check out our guide for contributors!

I don’t have any immediate plans to use it, but I love geeking out about I/O library design! That’s a little weird? But let’s be honest, you’ll fit in great around here. We have a whole sub-forum for discussing structured concurrency (developers of other systems welcome!). Or check out our discussion of design choices, reading list, and issues tagged design-discussion.

I want to make sure my company’s lawyers won’t get angry at me! No worries, Trio is permissively licensed under your choice of MIT or Apache 2. See LICENSE for details.

Code of conduct

Contributors are requested to follow our code of conduct in all project spaces.

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

trio-0.32.0.tar.gz (605.3 kB view details)

Uploaded Source

Built Distribution

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

trio-0.32.0-py3-none-any.whl (512.0 kB view details)

Uploaded Python 3

File details

Details for the file trio-0.32.0.tar.gz.

File metadata

  • Download URL: trio-0.32.0.tar.gz
  • Upload date:
  • Size: 605.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for trio-0.32.0.tar.gz
Algorithm Hash digest
SHA256 150f29ec923bcd51231e1d4c71c7006e65247d68759dd1c19af4ea815a25806b
MD5 8bc9dbdc265c291c93006f5e0f1d3918
BLAKE2b-256 d8ce0041ddd9160aac0031bcf5ab786c7640d795c797e67c438e15cfedf815c8

See more details on using hashes here.

Provenance

The following attestation bundles were made for trio-0.32.0.tar.gz:

Publisher: release.yml on python-trio/trio

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

File details

Details for the file trio-0.32.0-py3-none-any.whl.

File metadata

  • Download URL: trio-0.32.0-py3-none-any.whl
  • Upload date:
  • Size: 512.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for trio-0.32.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4ab65984ef8370b79a76659ec87aa3a30c5c7c83ff250b4de88c29a8ab6123c5
MD5 5024b7b0f8e7d4a338a73422015f0d04
BLAKE2b-256 41bf945d527ff706233636c73880b22c7c953f3faeb9d6c7e2e85bfbfd0134a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for trio-0.32.0-py3-none-any.whl:

Publisher: release.yml on python-trio/trio

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