stm-containers
stm-conduit
Our great sponsors
stm-containers | stm-conduit | |
---|---|---|
2 | - | |
62 | 41 | |
- | - | |
5.6 | 3.8 | |
6 months ago | 9 months ago | |
Haskell | Haskell | |
MIT License | BSD 3-clause "New" or "Revised" License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
stm-containers
-
Software Transactional Memory (1997)
I think you are right about STM being roughly equivalent to snapshot isolation.
What STM offers is an easy way to invent "containers for snapshotted values" aka TVars. Using them carefully may result in better scaling: https://hackage.haskell.org/package/stm-containers
-
How to achieve "Run at most one parallel async action per user"?
how about use stm-containers?
stm-conduit
We haven't tracked posts mentioning stm-conduit yet.
Tracking mentions began in Dec 2020.
What are some alternatives?
stm-incremental - A very simple interface for incremental computation using STM in Haskell.
streamly - High performance, concurrent functional programming abstractions
restricted-workers - Interactive-diagrams
stm-chunked-queues - Thread communication queues that group items/requests that occur close together in time
stm-channelize - Transactional I/O for duplex streams
theatre - Minimalistic actor library for Haskell
throttle-io-stream - Throttler between a producer and a consumer function
named-lock - A named lock that is created on demand.
conceit - Concurrently + Either
stm-queue-extras - Extra utilities for STM queues