Introduction to Crunch

The Arvados “Crunch” framework is designed to support processing very large data batches (gigabytes to terabytes) efficiently, and provides the following benefits:

  • Increase concurrency by running tasks asynchronously, using many CPUs and network interfaces at once (especially beneficial for CPU-bound and I/O-bound tasks respectively).
  • Track inputs, outputs, and settings so you can verify that the inputs, settings, and sequence of programs you used to arrive at an output is really what you think it was.
  • Ensure that your programs and workflows are repeatable with different versions of your code, OS updates, etc.
  • Interrupt and resume long-running jobs consisting of many short tasks.
  • Maintain timing statistics automatically, so they’re there when you want them.

Prerequisites

To get the most value out of this section, you should be comfortable with the following:

  1. Using a secure shell client such as SSH or PuTTY to log on to a remote server
  2. Using the Unix command line shell, Bash
  3. Viewing and editing files using a unix text editor such as vi, Emacs, or nano
  4. Programming in Python
  5. Revision control using Git

We also recommend you read the Arvados Platform Overview for an introduction and background information about Arvados.


Previous: Working with an Arvados git repository Next: Writing a CWL workflow

The content of this documentation is licensed under the Creative Commons Attribution-Share Alike 3.0 United States licence.
Code samples in this documentation are licensed under the Apache License, Version 2.0.