You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@gobblin.apache.org by "ASF GitHub Bot (Jira)" <ji...@apache.org> on 2023/02/09 16:03:01 UTC

[jira] [Work logged] (GOBBLIN-1784) Race condition where on service restart DagManager will lose track of dags

     [ https://issues.apache.org/jira/browse/GOBBLIN-1784?focusedWorklogId=844605&page=com.atlassian.jira.plugin.system.issuetabpanels:worklog-tabpanel#worklog-844605 ]

ASF GitHub Bot logged work on GOBBLIN-1784:
-------------------------------------------

                Author: ASF GitHub Bot
            Created on: 09/Feb/23 16:02
            Start Date: 09/Feb/23 16:02
    Worklog Time Spent: 10m 
      Work Description: Will-Lo opened a new pull request, #3641:
URL: https://github.com/apache/gobblin/pull/3641

   Dear Gobblin maintainers,
   
   Please accept this PR. I understand that it will not be reviewed until I have checked off all the steps below!
   
   
   ### JIRA
   - [x] My PR addresses the following [Gobblin JIRA](https://issues.apache.org/jira/browse/GOBBLIN/) issues and references them in the PR title. For example, "[GOBBLIN-XXX] My Gobblin PR"
       - https://issues.apache.org/jira/browse/GOBBLIN-1784
   
   
   ### Description
   - [x] Here are some details about my PR, including screenshots (if applicable):
   Currently, the DagManager will poll a dag until it receives that the *job* has been completed/failed/cancelled, and then emit the flow event and clean up the dag. However, on service restart or crash, it is possible that the flow event never gets emitted. Since the dag is already cleaned up, this job status becomes stuck, and will never progress.
   
   To address this scenario, this PR only cleans up dags when the cleanup function polls that the *flow status* is completed. If it does not receive the flow status that the job is completed within 3 minutes of the dag finishing all of its jobs, then it will re-emit the flow event in case it was lost. 
   
   ### Tests
   - [x] My PR adds the following unit tests __OR__ does not need testing for this extremely good reason:
     - Modified existing tests to the DagManagerTest class to ensure that the cleanup is working as expected on flow events
   
   ### Commits
   - [x] My commits all reference JIRA issues in their subject lines, and I have squashed multiple commits if they address the same issue. In addition, my commits follow the guidelines from "[How to write a good git commit message](http://chris.beams.io/posts/git-commit/)":
       1. Subject is separated from body by a blank line
       2. Subject is limited to 50 characters
       3. Subject does not end with a period
       4. Subject uses the imperative mood ("add", not "adding")
       5. Body wraps at 72 characters
       6. Body explains "what" and "why", not "how"
   
   




Issue Time Tracking
-------------------

            Worklog Id:     (was: 844605)
    Remaining Estimate: 0h
            Time Spent: 10m

> Race condition where on service restart DagManager will lose track of dags
> --------------------------------------------------------------------------
>
>                 Key: GOBBLIN-1784
>                 URL: https://issues.apache.org/jira/browse/GOBBLIN-1784
>             Project: Apache Gobblin
>          Issue Type: Bug
>          Components: gobblin-service
>            Reporter: William Lo
>            Assignee: Abhishek Tiwari
>            Priority: Major
>          Time Spent: 10m
>  Remaining Estimate: 0h
>
> Gobblin-as-a-Service has a bug where on restart, the DagManager will clean up dags but a flow event is never sent.
> This leads to a scenario where if the event is never sent by the underlying notification system, the dag will already be cleaned up and thus the job status will permanently be stuck in a running state.
> The DagManager thus should only clean up its own reference of dags after it reads that the jobstatus monitor has properly saved the final flow status, and if a status hasn't been received by some timestamp (e.g. 5 mins), then the DagManager will re-emit the event in case it was lost.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)