问题:java
method:org.apache.hadoop.hdfs.DomainSocketFactory.<init>(DomainSocketFactory.java:69) The short-circuit local reads feature cannot be used because libhadoop cannot be loaded.node
不能使用local read的优化策略;apache
解决:dom
Hadoop的一大基本原则是移动计算的开销要比移动数据的开销小。所以,Hadoop一般是尽可能移动计算到拥有数据的节点上。这就使得Hadoop中读取数据的客户端DFSClient和提供数据的Datanode常常是在一个节点上,也就形成了不少“Local Reads”。socket
修改配置以下:oop
<configuration> <property> <name>dfs.client.read.shortcircuit</name> <value>true</value> </property> <property> <name>dfs.domain.socket.path</name> <value>/var/lib/hadoop-hdfs/dn_socket</value> </property> </configuration>
参考:优化
http://blog.csdn.net/jewes/article/details/40189263ui