C#中的Hadoop - 响应状态代码不表示成功:500(服务器错误)

时间:2013-09-17 22:14:39

标签: c# hadoop mapreduce hdfs hortonworks-data-platform

尝试在Hadoop集群上运行MapReduce作业时,我遇到了一个奇怪的异常。这里有趣的是我可以访问HDFS,但无法运行。

UriBuilder uriBuilder = new UriBuilder("192.168.16.132");
uriBuilder.Port = 8021;//8082;
var hadoop = Hadoop.Connect(uriBuilder.Uri, "username", "password");
hadoop.StorageSystem.MakeDirectory("user/username/test"); //This works
//establish job configuration
HadoopJobConfiguration myConfig = new HadoopJobConfiguration();
myConfig.InputPath = "/user/username/input";
myConfig.OutputFolder = "/user/username/output";
try
{
    //connect to cluster
    MapReduceResult jobResult = hadoop.MapReduceJob.Execute<MySimpleMapper, MySimpleReducer>(myConfig); //This does not work and produces an error: The remote name could not be resolved
    //write job result to console
    int exitCode = jobResult.Info.ExitCode;
    string exitStatus = "Failure";
    if (exitCode == 0) exitStatus = "Success";
        exitStatus = exitCode + " (" + exitStatus + ")";
    Console.WriteLine();
    Console.Write("Exit Code = " + exitStatus);
    Console.Read();
}
catch (Exception exc)
{
    //Error sending request.
}

我正在使用Hortonworks沙箱进行测试,如果它有任何区别的话。 确切的错误是:“无法解析远程名称:'sandbox'”。

有人可以解释为什么会发生这种情况以及我可以做些什么来解决它?

编辑:我已通过将Hadoop集群的IP添加到hosts文件来修复此问题,但是现在我收到以下异常:“响应状态代码不表示成功:500(服务器错误)。”

1 个答案:

答案 0 :(得分:0)

事实证明,服务器不在Windows Azure上,而是Apache实现。协议不兼容。 HDFS协议对于两种实现都是相同的,因此这可以工作。但是,Map / Reduce框架不受支持。