<ahref="http://maven.apache.org/"title="Built by Maven"class="poweredBy">
<imgalt="Built by Maven"src="../../images/logos/maven-feather.png"/>
</a>
</div>
</div>
<divid="bodyColumn">
<divid="contentBox">
<!---
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
-->
<h1>Apache Hadoop 2.6.0 Release Notes</h1>
<p>These release notes cover new developer and user-facing incompatibilities, important issues, features, and major improvements.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HADOOP-10244">HADOOP-10244</a> | <i>Major</i> | <b>TestKeyShell improperly tests the results of a Delete</b></li>
</ul>
<p>Fix of inappropriate test of delete functionality.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HADOOP-10583">HADOOP-10583</a> | <i>Minor</i> | <b>bin/hadoop key throws NPE with no args and assorted other fixups</b></li>
</ul>
<p>bin/hadoop key with no args would throw an NPE.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HDFS-2856">HDFS-2856</a> | <i>Major</i> | <b>Fix block protocol so that Datanodes don’t require root or jsvc</b></li>
</ul>
<p>SASL now can be used to secure the DataTransferProtocol, which transfers file block content between HDFS clients and DataNodes. In this configuration, it is no longer required for secured clusters to start the DataNode as root and bind to privileged ports.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HADOOP-10839">HADOOP-10839</a> | <i>Major</i> | <b>Add unregisterSource() to MetricsSystem API</b></li>
</ul>
<p>The MetricsSystem abstract class has added a new abstract method, unregisterSource, for unregistering a previously registered metrics source. Custom subclasses of MetricsSystem must be updated to provide an implementation of this method.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HADOOP-8069">HADOOP-8069</a> | <i>Major</i> | <b>Enable TCP_NODELAY by default for IPC</b></li>
</ul>
<p>This change enables the TCP_NODELAY flag for all Hadoop IPC connections, hence bypassing TCP Nagling. Nagling interacts poorly with TCP delayed ACKs especially for request-response protocols.</p><hr/>
<p>The directory structure for finalized replicas on DNs has been changed. Now, the directory that a finalized replica goes in is determined uniquely by its ID. Specifically, we use a two-level directory structure, with the 24th through 17th bits identifying the correct directory at the first level and the 16th through 8th bits identifying the correct directory at the second level.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HADOOP-10903">HADOOP-10903</a> | <i>Major</i> | <b>Enhance hadoop classpath command to expand wildcards or write classpath into jar manifest.</b></li>
</ul>
<p>The “hadoop classpath” command has been enhanced to support options for automatic expansion of wildcards in classpath elements and writing the classpath to a jar file manifest. These options make it easier to construct a correct classpath for libhdfs applications.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HDFS-573">HDFS-573</a> | <i>Major</i> | <b>Porting libhdfs to Windows</b></li>
</ul>
<p>The libhdfs C API is now supported on Windows.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HADOOP-8944">HADOOP-8944</a> | <i>Trivial</i> | <b>Shell command fs -count should include human readable option</b></li>
</ul>
<p>Implements -h option for fs -count to show file sizes in human readable format. Additionally, ContentSummary.getHeader() now returns a different string that is incompatible with previous releases.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HDFS-6376">HDFS-6376</a> | <i>Major</i> | <b>Distcp data between two HA clusters requires another configuration</b></li>
</ul>
<p>Allow distcp to copy data between HA clusters. Users can use a new configuration property “dfs.internal.nameservices” to explicitly specify the name services belonging to the local cluster, while continue using the configuration property “dfs.nameservices” to specify all the name services in the local and remote clusters.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/YARN-668">YARN-668</a> | <i>Blocker</i> | <b>TokenIdentifier serialization should consider Unknown fields</b></li>
</ul>
<p><b>WARNING: No release note provided for this change.</b></p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/YARN-1051">YARN-1051</a> | <i>Major</i> | <b>YARN Admission Control/Planner: enhancing the resource allocation model with time.</b></li>
</ul>
<p><b>WARNING: No release note provided for this change.</b></p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HADOOP-10681">HADOOP-10681</a> | <i>Major</i> | <b>Remove synchronized blocks from SnappyCodec and ZlibCodec buffering inner loop</b></li>
</ul>
<p>Remove unnecessary synchronized blocks from Snappy/Zlib codecs.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/YARN-2615">YARN-2615</a> | <i>Blocker</i> | <b>ClientToAMTokenIdentifier and DelegationTokenIdentifier should allow extended fields</b></li>
</ul>
<p><b>WARNING: No release note provided for this change.</b></p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HDFS-6606">HDFS-6606</a> | <i>Major</i> | <b>Optimize HDFS Encrypted Transport performance</b></li>
</ul>
<p>HDFS now supports the option to configure AES encryption for block data transfer. AES offers improved cryptographic strength and performance over the prior options of 3DES and RC4.</p><hr/>
<ul>
<li><aclass="externalLink"href="https://issues.apache.org/jira/browse/HDFS-7276">HDFS-7276</a> | <i>Major</i> | <b>Limit the number of byte arrays used by DFSOutputStream</b></li>
</ul>
<p>The following configuration properties are added.</p>
<ul>
<li>
<p>dfs.client.write.byte-array-manager.enabled: for enabling/disabling byte array manger. Default is false.</p>
</li>
<li>
<p>dfs.client.write.byte-array-manager.count-threshold: The count threshold for each array length so that a manager is created only after the allocation count exceeds the threshold. In other words, the particular array length is not managed until the allocation count exceeds the threshold. Default is 128.</p>
</li>
<li>
<p>dfs.client.write.byte-array-manager.count-limit: The maximum number of arrays allowed for each array length. Default is 2048.</p>
</li>
<li>
<p>dfs.client.write.byte-array-manager.count-reset-time-period-ms: The time period in milliseconds that the allocation count for each array length is reset to zero if there is no increment. Default is 10,000ms, i.e. 10 seconds.</p>