A datum is the smallest indivisible unit of computation within a job. Datums are used to:
- Divide your input data
- Distribute processing workloads
A datum’s scope can be as large as all of your data at once, a directory, a file, or a combination of multiple inputs. The shape and quantity of your datums is determined by a glob pattern defined in your pipeline specification.
A job can have one, many, or no datums. Each datum is processed independently with a single execution of the user code on one of the pipeline worker pods. The individual output files produced by all of your datums are combined to create the final output commit.
If a job is successfully executed but has no matching files to transform, it is considered a zero-datum job.
Datum Processing States #
When a pipeline runs, it processes your datums. Some of them get processed successfully and some might be skipped or even fail. Generally, processed datums fall into either successful or failure state category.
Successful States #
|The datum has been successfully processed in this job.
|The datum has been successfully processed in a previous job, has not changed since then, and therefore, it was skipped in the current job.
Failure States #
|The datum failed to be processed. Any failed datum in a job fails the whole job.
|The datum failed, but was recovered by the user’s error handling code. Although the datum is marked as recovered, Pachyderm does not process it in the downstream pipelines. A recovered datum does not fail the whole job. Just like failed datums, recovered datums are retried on the next run of the pipeline.
You can view the information about datum processing states in the output of
pachctl list job <jobID> command:
Datums that failed are still included in the total, but not shown in the progress indicator.
A job restarts when an internal error (not the user code) occurs while processing a job. These occurrences are counted in the