Ten simple rules for writing Dockerfiles for reproducible data science

PLoS Comput Biol. 2020 Nov 10;16(11):e1008316. doi: 10.1371/journal.pcbi.1008316. eCollection 2020 Nov.

Abstract

Computational science has been greatly improved by the use of containers for packaging software and data dependencies. In a scholarly context, the main drivers for using these containers are transparency and support of reproducibility; in turn, a workflow's reproducibility can be greatly affected by the choices that are made with respect to building containers. In many cases, the build process for the container's image is created from instructions provided in a Dockerfile format. In support of this approach, we present a set of rules to help researchers write understandable Dockerfiles for typical data science workflows. By following the rules in this article, researchers can create containers suitable for sharing with fellow scientists, for including in scholarly communication such as education or scientific papers, and for effective and sustainable personal workflows.

Publication types

  • Editorial
  • Research Support, Non-U.S. Gov't

MeSH terms

  • Algorithms
  • Data Science*
  • Guidelines as Topic*
  • Programming Languages*
  • Reproducibility of Results
  • Software*