Java API 访问HA模式下的HDFS集群

在使用Hadoop Java API访问HDFS集群时,在创建FileSystem对象时,直接指定NameNode的IP以及端口号即可。但是在HA模式下,访问HDFS集群却有一些不同,需要指定NameSpace和主备NameNode的IP以及端口等信息,具体操作方式见如下代码:

Configuration conf = new Configuration();
conf.set("fs.defaultFS", "hdfs://ns1");
conf.set("dfs.nameservices", "ns1");
conf.set("dfs.ha.namenodes.ns1", "nn1,nn2");
conf.set("dfs.namenode.rpc-address.ns1.nn1", "namenode1:9000");
conf.set("dfs.namenode.rpc-address.ns1.nn2", "namenode2:9000");
//conf.setBoolean(name, value);
conf.set("dfs.client.failover.proxy.provider.ns1", "org.apache.hadoop.hdfs.server.namenode.ha.ConfiguredFailoverProxyProvider");
FileSystem fs = FileSystem.get(new URI("hdfs://ns1"), conf, "hadoop");

另外还可以将Hadoop的配置文件core-site.xml和hdfs-site.xml拷到程序目录下,以输入流的方式加载到Configuration配置信息中。在实际工作中可能没有使用core-site.xml和hdfs-site.xml的权限,所以还是使用第一种方法。

猜你喜欢

转载自blog.csdn.net/twj0823/article/details/84346176
今日推荐