Difference between revisions of "Concurrency"
m (GHC/Concurrency moved to Concurrency: This page is more useful outside a GHC-specific context) |
m |
||
(14 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
+ | ''Note: you may want to read [[Parallelism vs. Concurrency]], as the terms have historically been conflated.'' |
||
⚫ | |||
⚫ | |||
+ | This page contains notes and information about how to write concurrent programs in Haskell. |
||
− | == Concurrent Programming in GHC == |
||
+ | For practicality, the content is GHC-centric at the moment, although this may change as Haskell evolves. |
||
− | This page contains notes and information about how to write concurrent programs in GHC. If you're more interested in performance than non-determinism, learn about writing [[GHC/Parallelism|parallel]] programs instead. |
||
+ | == Overview == |
||
⚫ | GHC provides multi-scale support for |
||
⚫ | GHC provides multi-scale support for concurrent programming, from very fine-grained, small tasks to coarse-grained explicit threads and locks, along with other models of concurrent programming including actors, CSP-style concurrency, and Intel Concurrent Collections. Synchronization between tasks is possible via messages, regular Haskell variables, <code>MVar</code>-based shared state or transactional memory. |
||
⚫ | |||
− | |||
− | The concurrent programming models in GHC can be divided into the following forms: |
||
+ | == Getting started == |
||
− | * Lightweight Haskell threads, explicit synchronization with STM or MVars. See the paper "Tackling the Awkward Squad" below. |
||
⚫ | |||
+ | # Manage simultaneous I/O actions (eg. multiple connections on a web server) |
||
− | The most important (as of 2010) to get to know are the basic "concurrent Haskell" model of threads using forkIO and MVars, the use of transactional memory via STM. |
||
+ | #: Start with Concurrent Haskell (<code>forkIO</code>, <code>MVar</code>) |
||
+ | #: [[Parallel/Reading|Learn more about concurrency]], then try using [[Applications_and_libraries/Network#Libraries|network protocol libraries]] like HTTP or zeromq. |
||
+ | # Work with clusters or do distributed programming |
||
+ | #: Look out for [[Parallel/Research|ongoing research]] into distributed Haskell. |
||
− | + | == Digging deeper == |
|
⚫ | |||
− | * '''Basic concurrency: forkIO and MVars'''. |
||
⚫ | : STM was added to GHC 6.4, and is described in the paper [https://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.67.3686&rep=rep1&type=pdf Composable memory transactions]. The paper [https://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.64.1678&rep=rep1&type=pdf Lock-free data structures using STM in Haskell] gives further examples of concurrent programming using STM. |
||
⚫ | |||
⚫ | : STM was added to GHC 6.4, and is described in the paper [ |
||
− | * '''Foreign function interface'''. If you are calling foreign functions in a concurrent program, you need to know about ''bound threads''. They are described in a Haskell workshop paper, [ |
+ | * '''Foreign function interface'''. If you are calling foreign functions in a concurrent program, you need to know about ''bound threads''. They are described in a Haskell workshop paper, [https://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.80.4811&rep=rep1&type=pdf Extending the Haskell Foreign Function Interface with Concurrency]. The GHC Commentary [http://darcs.haskell.org/ghc/docs/comm/rts-libs/multi-thread.html Supporting multi-threaded interoperation] contains more detailed explanation of cooperation between FFI calls and multi-threaded runtime. |
− | + | == GHC concurrency specifics == |
|
− | + | You get access to concurrency operations by importing the library [http://www.haskell.org/ghc/docs/latest/html/libraries/base/Control-Concurrent.html Control.Concurrent]. |
|
+ | == Community == |
||
− | * The GHC manual gives a few useful flags that control scheduling (not usually necessary) [http://www.haskell.org/ghc/docs/latest/html/users_guide/sec-using-parallel.html#parallel-rts-opts RTS options]. |
||
+ | |||
+ | * Ask questions on [[Mailing lists|Haskell Cafe]] |
||
+ | * See what [https://groups.google.com/group/concurrent-haskell concurrent-haskell] researchers and developers are working on |
||
+ | * Follow [http://twitter.com/#!/concurrenthaskell @concurrenthaskell] on Twitter [[image:Twitter-mini.png]] |
||
+ | * StackOverflow on Haskell: [http://stackoverflow.com/questions/tagged/haskell%2bconcurrency concurrency] |
||
+ | |||
+ | == Tools == |
||
+ | |||
+ | * [[ThreadScope]] - concurrent programs not working as expected? Use the ThreadScope debugger and watch the fireworks. |
||
+ | * Various [[Applications and libraries/Concurrency and parallelism|libraries]], including those for concurrency. |
||
+ | |||
+ | == Documentation == |
||
+ | |||
+ | * [[Parallel/Glossary|Glossary]] |
||
⚫ | |||
+ | * [[Parallel/Research|Current research]] |
||
+ | * [http://chimera.labs.oreilly.com/books/1230000000929/index.html ... Concurrent Programming in Haskell] (online book) |
||
+ | |||
+ | == Alternative approaches == |
||
+ | |||
⚫ | |||
− | + | == See also == |
|
+ | * [[:Category:Concurrency|Concurrency]] category |
||
− | {{GHC/Multicore}} |
||
+ | * Concurrency [[Parallel/Research|research]] |
||
− | === Related work === |
||
⚫ | |||
− | * The Sun project to improve http://ghcsparc.blogspot.com/ GHC performance on Sparc] |
||
⚫ | |||
− | * A [http://www.well-typed.com/blog/38 Microsoft project to improve industrial applications of GHC parallelism]. |
||
− | * [http://www.haskell.org/~simonmar/bib/bib.html Simon Marlow's publications on parallelism and GHC] |
||
− | * [http://www.macs.hw.ac.uk/~dsg/gdh/ Glasgow Distributed Haskell] |
||
− | * http://www-i2.informatik.rwth-aachen.de/~stolz/dhs/ |
||
− | * http://www.informatik.uni-kiel.de/~fhu/PUBLICATIONS/1999/ifl.html |
||
− | * [http://www.mathematik.uni-marburg.de/~eden Eden] |
Latest revision as of 09:56, 15 May 2024
Note: you may want to read Parallelism vs. Concurrency, as the terms have historically been conflated.
This page contains notes and information about how to write concurrent programs in Haskell.
For practicality, the content is GHC-centric at the moment, although this may change as Haskell evolves.
Overview
GHC provides multi-scale support for concurrent programming, from very fine-grained, small tasks to coarse-grained explicit threads and locks, along with other models of concurrent programming including actors, CSP-style concurrency, and Intel Concurrent Collections. Synchronization between tasks is possible via messages, regular Haskell variables, MVar
-based shared state or transactional memory.
Getting started
- Manage simultaneous I/O actions (eg. multiple connections on a web server)
- Start with Concurrent Haskell (
forkIO
,MVar
) - Learn more about concurrency, then try using network protocol libraries like HTTP or zeromq.
- Start with Concurrent Haskell (
- Work with clusters or do distributed programming
- Look out for ongoing research into distributed Haskell.
Digging deeper
- Software Transactional Memory (STM) is a newer way to coordinate concurrent threads. There's a separate Wiki page devoted to STM.
- STM was added to GHC 6.4, and is described in the paper Composable memory transactions. The paper Lock-free data structures using STM in Haskell gives further examples of concurrent programming using STM.
- Foreign function interface. If you are calling foreign functions in a concurrent program, you need to know about bound threads. They are described in a Haskell workshop paper, Extending the Haskell Foreign Function Interface with Concurrency. The GHC Commentary Supporting multi-threaded interoperation contains more detailed explanation of cooperation between FFI calls and multi-threaded runtime.
GHC concurrency specifics
You get access to concurrency operations by importing the library Control.Concurrent.
Community
- Ask questions on Haskell Cafe
- See what concurrent-haskell researchers and developers are working on
- Follow @concurrenthaskell on Twitter
- StackOverflow on Haskell: concurrency
Tools
- ThreadScope - concurrent programs not working as expected? Use the ThreadScope debugger and watch the fireworks.
- Various libraries, including those for concurrency.
Documentation
- Glossary
- Learning to use concurrency in Haskell
- Current research
- ... Concurrent Programming in Haskell (online book)
Alternative approaches
- CHP: CSP-style concurrency for Haskell.
See also
- Concurrency category
- Concurrency research