hadoop-hdfs-issues mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Hudson (JIRA)" <j...@apache.org>
Subject [jira] [Commented] (HDFS-9250) Add Precondition check to LocatedBlock#addCachedLoc
Date Mon, 19 Oct 2015 23:26:27 GMT

    [ https://issues.apache.org/jira/browse/HDFS-9250?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=14964237#comment-14964237
] 

Hudson commented on HDFS-9250:
------------------------------

FAILURE: Integrated in Hadoop-trunk-Commit #8666 (See [https://builds.apache.org/job/Hadoop-trunk-Commit/8666/])
HDFS-9250. Add Precondition check to LocatedBlock#addCachedLoc. (wang: rev 8175c4f6b9fc17ff2e0fc568d798f9b6f2487696)
* hadoop-hdfs-project/hadoop-hdfs/CHANGES.txt
* hadoop-hdfs-project/hadoop-hdfs/src/test/java/org/apache/hadoop/hdfs/protocol/TestLocatedBlock.java
* hadoop-hdfs-project/hadoop-hdfs-client/src/main/java/org/apache/hadoop/hdfs/protocol/LocatedBlock.java


> Add Precondition check to LocatedBlock#addCachedLoc
> ---------------------------------------------------
>
>                 Key: HDFS-9250
>                 URL: https://issues.apache.org/jira/browse/HDFS-9250
>             Project: Hadoop HDFS
>          Issue Type: Improvement
>          Components: HDFS
>    Affects Versions: 2.4.0
>            Reporter: Xiao Chen
>            Assignee: Xiao Chen
>             Fix For: 2.8.0
>
>         Attachments: HDFS-9250.001.patch, HDFS-9250.002.patch
>
>
> We may see the following exception:
> {noformat}
> java.lang.ArrayStoreException
> at java.util.ArrayList.toArray(ArrayList.java:389)
> at org.apache.hadoop.hdfs.protocol.LocatedBlock.addCachedLoc(LocatedBlock.java:205)
> at org.apache.hadoop.hdfs.server.namenode.CacheManager.setCachedLocations(CacheManager.java:907)
> at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.getBlockLocationsUpdateTimes(FSNamesystem.java:1974)
> at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.getBlockLocationsInt(FSNamesystem.java:1873)
> {noformat}
> The cause is that in LocatedBlock.java, when {{addCachedLoc}}:
> - Passed in parameter {{loc}}, which is type {{DatanodeDescriptor}}, is added to {{cachedList}}
> - {{cachedList}} was assigned to {{EMPTY_LOCS}}, which is type {{DatanodeInfoWithStorage}}.
> Both {{DatanodeDescriptor}} and {{DatanodeInfoWithStorage}} are subclasses of {{DatanodeInfo}}
but do not inherit from each other, resulting in the ArrayStoreException.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Mime
View raw message