Blog Post

Azure Data Factory Blog
2 MIN READ

Understanding Pipeline Failures and Error Handling 2

ChenyeCharlieZhu's avatar
Apr 29, 2021

In our previous installment of Understanding Pipeline Failures and Error Handling, we introduced the difference between TRY-CATCH logic and DO-IF-ELSE logic.

 

Just a memory refresher, DO-IF-ELSE logic defines both Upon_Success and Upon_Failure paths

 If we execute this pipeline, with WillFail activity failing, the whole pipeline will be marked as Failed, as expected

 

Sometimes users may want a more elegant error handling in their pipeline: despite branching activity (WillFail in this case) failed, I do not want to mark the whole pipeline as Failed, maybe because

  • I do not want to block downstream dependent tumbling windows, in case of tumbling window dependency
  • branching activity is used to look up a control table, and sometimes it is expected to return empty results and throw an error

To implement the desired behavior, customers may consider DO-IF-SKIP-ELSE block: adding a dummy UponSkipped to the end of the UponSuccess path, like this

 

If we run this pipeline, WillFail will still fail, but the pipeline will be marked as SUCCESS

 

In the monitoring view, you can see the difference a dummy UponSkipped activity can make. Notice that PipelineErrorHandlingSuccess is defined with the addition dummy activity, while PipeErrorHandling is not. (And the additional pipeline duration comes from the extra 5 seconds in the dummy wait activity)

 

Technical reasons for the difference is that, Azure Data Factory defines pipeline success and failures as follows:

  • Evaluate outcome for all leaves activities. If a leaf activity was skipped, we evaluate its parent activity instead
  • Pipeline result is success if and only if all leaves succeed

 

Here is an expanded table summarizing the difference:

 

Approach Error Handling Defines When Activity Succeeds When Activity Fails
TRY-CATCH Only Upon Failure path Pipeline shows Success Pipeline shows Success
DO-IF-ELSE

Upon Failure paths

+

Upon Success path

Pipeline shows Success Pipeline shows Failure
DO-IF-SKIP-ELSE

Upon Failure paths

+

Upon Success path (with a dummy Upon Skipped activity at the end)

 

Pipeline shows Success Pipeline shows Success

 

Updated Apr 29, 2021
Version 2.0
  • Thanks, this post helped me understand and overcome a problem I had in my Data Factory.

    Please add this information to ADF's official documentation! 🙂

     

    Michael