Journal article Open Access
Iacopo Colonnelli;
Marco Aldinucci;
Barbara Cantalupo;
et al.
The designers of a new coordination interface enacting complex workflows have to tackle a dichotomy: choosing a language-independent or language-dependent approach. Language-independent approaches decouple workflow models from the host code’s business logic and advocate portability. Language-dependent approaches foster flexibility and performance by adopting the same host language for business and coordination code. Jupyter Notebooks, with their capability to describe both imperative and declarative code in a unique format, allow taking the best of the two approaches, maintaining a clear separation between application and coordination layers but still providing a unified interface to both aspects. We advocate the Jupyter Notebooks’ potential to express complex distributed workflows, identifying the general requirements for a Jupyter-based Workflow Management System (WMS) and introducing a proof-of-concept portable implementation working on hybrid Cloud-HPC infrastructures. As a byproduct, we extended the vanilla IPython kernel with workflow-based parallel and distributed execution capabilities. The proposed Jupyter-workflow (Jw) system is evaluated on common scenarios for High Performance Computing (HPC) and Cloud, showing its potential in lowering the barriers between prototypical Notebooks and production-ready implementations.
Name | Size | |
---|---|---|
DistributedWorkflowWithJupyter.pdf
md5:9fc5a9ca8ec35d3d512710b1fb32fb27 |
1.5 MB | Download |
Views | 38 |
Downloads | 40 |
Data volume | 61.5 MB |
Unique views | 30 |
Unique downloads | 31 |