multiprocessing
 â Process-based parallelism
Source code:Â Lib/multiprocessing/
multiprocessing
 is a package that supports spawning processes using an API similar to theÂthreading
 module. TheÂmultiprocessing
 package offers both local and remote concurrency, effectively side-stepping the Global Interpreter Lock by using subprocesses instead of threads. Due to this, theÂmultiprocessing
 module allows the programmer to fully leverage multiple processors on a given machine. It runs on both Unix and Windows.
TheÂ
multiprocessing
 module also introduces APIs which do not have analogs in theÂthreading
 module. A prime example of this is theÂPool
 object which offers a convenient means of parallelizing the execution of a function across multiple input values, distributing the input data across processes (data parallelism). The following example demonstrates the common practice of defining such functions in a module so that child processes can successfully import that module.This basic example of data parallelism usingÂ
Pool
:
from multiprocessing import Pool
def f(x):
return x*x
if __name__ == '__main__':
with Pool(5) as p:
print(p.map(f, [1, 2, 3]))
Asyncio in Python
- Coroutines and Tasks - Python official docs with asyncio
- Async IO in Python A Complete Walkthrough â Real Python
- How does asyncio actually work? excellent, elucidating post