Uploaded image for project: 'Hadoop Map/Reduce'
  1. Hadoop Map/Reduce
  2. MAPREDUCE-6846

Fragments specified for libjar paths are not handled correctly

    XMLWordPrintableJSON

Details

    • Bug
    • Status: Resolved
    • Minor
    • Resolution: Fixed
    • 2.6.0, 2.7.3, 3.0.0-alpha2
    • 2.9.0, 3.0.0-alpha4
    • None
    • None
    • Reviewed

    Description

      If a user specifies a fragment for a libjars path via generic options parser, the client crashes with a FileNotFoundException:

      java.io.FileNotFoundException: File file:/home/mapred/test.txt#testFrag.txt does not exist
      	at org.apache.hadoop.fs.RawLocalFileSystem.deprecatedGetFileStatus(RawLocalFileSystem.java:638)
      	at org.apache.hadoop.fs.RawLocalFileSystem.getFileLinkStatusInternal(RawLocalFileSystem.java:864)
      	at org.apache.hadoop.fs.RawLocalFileSystem.getFileStatus(RawLocalFileSystem.java:628)
      	at org.apache.hadoop.fs.FilterFileSystem.getFileStatus(FilterFileSystem.java:442)
      	at org.apache.hadoop.fs.FileUtil.copy(FileUtil.java:363)
      	at org.apache.hadoop.fs.FileUtil.copy(FileUtil.java:314)
      	at org.apache.hadoop.mapreduce.JobResourceUploader.copyRemoteFiles(JobResourceUploader.java:387)
      	at org.apache.hadoop.mapreduce.JobResourceUploader.uploadLibJars(JobResourceUploader.java:154)
      	at org.apache.hadoop.mapreduce.JobResourceUploader.uploadResources(JobResourceUploader.java:105)
      	at org.apache.hadoop.mapreduce.JobSubmitter.copyAndConfigureFiles(JobSubmitter.java:102)
      	at org.apache.hadoop.mapreduce.JobSubmitter.submitJobInternal(JobSubmitter.java:197)
      	at org.apache.hadoop.mapreduce.Job$11.run(Job.java:1344)
      	at org.apache.hadoop.mapreduce.Job$11.run(Job.java:1341)
      	at java.security.AccessController.doPrivileged(Native Method)
      	at javax.security.auth.Subject.doAs(Subject.java:422)
      	at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1892)
      	at org.apache.hadoop.mapreduce.Job.submit(Job.java:1341)
      	at org.apache.hadoop.mapreduce.Job.waitForCompletion(Job.java:1362)
      	at org.apache.hadoop.examples.QuasiMonteCarlo.estimatePi(QuasiMonteCarlo.java:306)
      	at org.apache.hadoop.examples.QuasiMonteCarlo.run(QuasiMonteCarlo.java:359)
      	at org.apache.hadoop.util.ToolRunner.run(ToolRunner.java:76)
      	at org.apache.hadoop.examples.QuasiMonteCarlo.main(QuasiMonteCarlo.java:367)
      	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
      	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
      	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      	at java.lang.reflect.Method.invoke(Method.java:498)
      	at org.apache.hadoop.util.ProgramDriver$ProgramDescription.invoke(ProgramDriver.java:71)
      	at org.apache.hadoop.util.ProgramDriver.run(ProgramDriver.java:144)
      	at org.apache.hadoop.examples.ExampleDriver.main(ExampleDriver.java:74)
      	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
      	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
      	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
      	at java.lang.reflect.Method.invoke(Method.java:498)
      	at org.apache.hadoop.util.RunJar.run(RunJar.java:239)
      	at org.apache.hadoop.util.RunJar.main(RunJar.java:153)
      

      This is actually inconsistent with the behavior for files and archives. Here is a table showing the current behavior for each type of path and resource:

        Qualified path (i.e. file://home/mapred/test.txt#frag.txt) Absolute path (i.e. /home/mapred/test.txt#frag.txt) Relative path (i.e. test.txt#frag.txt)
      -libjars FileNotFound FileNotFound FileNotFound
      -files
      -archives

      Attachments

        1. MAPREDUCE-6846-trunk.006.patch
          34 kB
          Chris Trezzo
        2. MAPREDUCE-6846-trunk.005.patch
          33 kB
          Chris Trezzo
        3. MAPREDUCE-6846-trunk.004.patch
          33 kB
          Chris Trezzo
        4. MAPREDUCE-6846-trunk.003.patch
          34 kB
          Chris Trezzo
        5. MAPREDUCE-6846-trunk.002.patch
          35 kB
          Chris Trezzo
        6. MAPREDUCE-6846-trunk.001.patch
          32 kB
          Chris Trezzo

        Issue Links

          Activity

            People

              ctrezzo Chris Trezzo
              ctrezzo Chris Trezzo
              Votes:
              0 Vote for this issue
              Watchers:
              9 Start watching this issue

              Dates

                Created:
                Updated:
                Resolved: