diff --git a/dolphinscheduler-master/src/main/java/org/apache/dolphinscheduler/server/master/runner/WorkflowExecuteRunnable.java b/dolphinscheduler-master/src/main/java/org/apache/dolphinscheduler/server/master/runner/WorkflowExecuteRunnable.java index 4cbfb3b826..57a624d8f6 100644 --- a/dolphinscheduler-master/src/main/java/org/apache/dolphinscheduler/server/master/runner/WorkflowExecuteRunnable.java +++ b/dolphinscheduler-master/src/main/java/org/apache/dolphinscheduler/server/master/runner/WorkflowExecuteRunnable.java @@ -1419,8 +1419,11 @@ public class WorkflowExecuteRunnable implements Callable { */ private void setIndirectDepList(String taskCode, List indirectDepCodeList) { TaskNode taskNode = dag.getNode(taskCode); - List depCodeList = taskNode.getDepList(); - for (String depsNode : depCodeList) { + // If workflow start with startNode or recoveryNode, taskNode may be null + if (taskNode == null) { + return; + } + for (String depsNode : taskNode.getDepList()) { if (forbiddenTaskMap.containsKey(Long.parseLong(depsNode))) { setIndirectDepList(depsNode, indirectDepCodeList); } else {