-Re: Adding a soft-linked archive file to the distributed cache doesn't work as advertised
Alejandro Abdelnur 2012-01-09, 19:05
In addition you must call DistributedCached.createSymlink(configuration),
that should do.
On Mon, Jan 9, 2012 at 10:30 AM, W.P. McNeill <[EMAIL PROTECTED]> wrote:
> I am trying to add a zip file to the distributed cache and have it unzipped
> on the task nodes with a softlink to the unzipped directory placed in the
> working directory of my mapper process. I think I'm doing everything the
> way the documentation tells me to, but it's not working.
> On the client in the run() function while I'm creating the job I first
> fs.copyFromLocalFile("gate-app.zip", "/tmp/gate-app.zip");
> As expected, this copies the archive file gate-app.zip to the HDFS
> directory /tmp.
> Then I call
> I expect this to add "/tmp/gate-app.zip" to the distributed cache and put a
> softlink to it called gate-app in the working directory of each task.
> However, when I call job.waitForCompletion(), I see the following error:
> Exception in thread "main" java.io.FileNotFoundException: File does not
> exist: /tmp/gate-app.zip#gate-app.
> It appears that the distributed cache mechanism is interpreting the entire
> URI as the literal name of the file, instead of treating the fragment as
> the name of the softlink.
> As far as I can tell, I'm doing this correctly according to the API
> The full project in which I'm doing this is up on github:
> Can someone tell me what I'm doing wrong?