我安装了hadoop 1.0.4。我启用了webhdfs并使用curl命令来获取主目录。
curl -i "http://172.16.30.40:50075/webhdfs/v1?user.name=ubantu&op=GETFILESTATUS"
它适用于GETHOMEDIRECTORY,但不适用于GETFILESTATUS,LISTSTATUS等其他操作
我异常(exception)
**{"RemoteException":{"exception":"FileNotFoundException","javaClassName":"java.io.FileNotFoundException","message":"File /webhdfs/v1 not found."}}**
这是conf文件:
hdfs-site.xml
<configuration>
<property>
<name>dfs.replication</name>
<value>3</value>
</property>
<property>
<name>dfs.webhdfs.enabled</name>
<value>true</value>
</property>
<property>
<name>dfs.support.append</name>
<value>true</value>
</property>
</configuration>
任何人都可以提出建议吗?
谢谢。
最佳答案
根据文档(http://hadoop.apache.org/docs/r1.0.4/webhdfs.html#GETHOMEDIRECTORY),要访问主目录,您应该使用curl -i "http://<HOST>:<PORT>/webhdfs/v1/?op=GETHOMEDIRECTORY"
另外,尝试使用:50070。那是我用于webdfs的端口,它工作正常。
curl -i "http://localhost:50070/webhdfs/v1/?op=GETHOMEDIRECTORY"
更新:
在您的示例中,您没有指定要检查其状态的文件路径。
在下面的示例中,如果您将/ path / to / your /替换为文件的路径,然后用文件名更改“file”,那么这对您有什么帮助?
curl -i "http://localhost:50070/webhdfs/v1/path/to/your/file?op=GETFILESTATUS"
关于java - 对webhdfs的Http请求但给出FileNotFoundException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15633133/