Uploaded image for project: 'Hadoop YARN'
  1. Hadoop YARN
  2. YARN-10087

ATS possible NPE on REST API when data is missing

Details

    • Bug
    • Status: Open
    • Major
    • Resolution: Unresolved
    • None
    • None
    • ATSv2

    Description

      If the data stored by the ATS is not complete REST calls to the ATS can return a NPE instead of results.

      {{

      {"exception":"NullPointerException","javaClassName":"java.lang.NullPointerException"}

      }}

      The issue shows up when the ATS was down for a short period and in that time new applications were started. This causes certain parts of the application data to be missing in the ATS store. In most cases this is not a problem and data will be returned but when you start filtering data the filtering fails throwing the NPE.
      In this case the request was for: http://<ATS-IP>:8188/ws/v1/applicationhistory/apps?user=hive'

      If certain pieces of data are missing the ATS should not even consider returning that data, filtered or not. We should not display partial or incomplete data.
      In case of the missing user information ACL checks cannot be correctly performed and we could see more issues.

      A similar issue was fixed in YARN-7118 where the queue details were missing. It just skips the app to prevent the NPE but that is not the correct thing when the user is missing

      Attachments

        1. ats_stack.txt
          5 kB
          wilfreds#1

        Activity

          wilfreds Wilfred Spiegelenburg added a comment - - edited

          Attached the NPE as logged in the ATS logs.

          The logs point to these lines of code in the release that was running:

          188 if (userQuery != null && !userQuery.isEmpty()) {
          189   if (!appReport.getUser().equals(userQuery)) {
          190     continue;
          191   }
          192 } 
          wilfreds Wilfred Spiegelenburg added a comment - - edited Attached the NPE as logged in the ATS logs. The logs point to these lines of code in the release that was running: 188 if (userQuery != null && !userQuery.isEmpty()) { 189 if (!appReport.getUser().equals(userQuery)) { 190 continue ; 191 } 192 }
          samrat007 Samrat Deb added a comment -

          tanu.ajmera , if you are not actively working on this bug !
          can i pick this up ?
          as a newbie , it would help me go deep dive into code and understand some of working and code working associated with ATS 

          samrat007 Samrat Deb added a comment - tanu.ajmera , if you are not actively working on this bug ! can i pick this up ? as a newbie , it would help me go deep dive into code and understand some of working and code working associated with ATS 
          samrat007 Samrat Deb added a comment -

          picking this up!

          samrat007 Samrat Deb added a comment - picking this up!

          People

            samrat007 Samrat Deb
            wilfreds Wilfred Spiegelenburg
            Votes:
            0 Vote for this issue
            Watchers:
            5 Start watching this issue

            Dates

              Created:
              Updated: