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

Vinayakumar B edited comment on HDFS-11708 at 5/28/17 9:57 AM:
---------------------------------------------------------------

Attached the patch for the update.

1. Reason for test's failure to detect issue during full run is HDFS-11898. 
{{TestPread#testPreadFailureWithChangedBlockLocations()}} was also using hedged 
reads, for which issue will not occur. Included those changes as well here for 
jenkins run.
2.
bq. It seems like a rather fancy way to update a block variable that got stale. 
Would've preferred something more explicit
Using the return value of {{choseDatanode()}} to return the updated {{block}} 
as well. So avoiding the redundant calls to {{refreshLocatedBlock()}};

Please give your thoughts.


was (Author: vinayrpet):
Attached the patch for the update.

1. Reason for test's failure to detect issue during full run is HDFS-11898. 
Included those changes as well here for jenkins run.
2.
bq. It seems like a rather fancy way to update a block variable that got stale. 
Would've preferred something more explicit
Using the return value of {{choseDatanode()}} to return the updated {{block}} 
as well. So avoiding the redundant calls to {{refreshLocatedBlock()}};

Please give your thoughts.

> positional read will fail if replicas moved to different DNs after stream is 
> opened
> -----------------------------------------------------------------------------------
>
>                 Key: HDFS-11708
>                 URL: https://issues.apache.org/jira/browse/HDFS-11708
>             Project: Hadoop HDFS
>          Issue Type: Bug
>          Components: hdfs-client
>    Affects Versions: 2.7.3
>            Reporter: Vinayakumar B
>            Assignee: Vinayakumar B
>            Priority: Critical
>              Labels: release-blocker
>         Attachments: HDFS-11708-01.patch, HDFS-11708-02.patch, 
> HDFS-11708-03.patch, HDFS-11708-04.patch, HDFS-11708-05.patch, 
> HDFS-11708-HDFS-11898-06.patch
>
>
> Scenario:
> 1. File was written to DN1, DN2 with RF=2
> 2. File stream opened to read and kept. Block Locations are [DN1,DN2]
> 3. One of the replica (DN2) moved to another datanode (DN3) due to datanode 
> dead/balancing/etc.
> 4. Latest block locations in NameNode will be DN1 and DN3 in the 'same order'
> 5. DN1 went down, but not yet detected as dead in NameNode.
> 6. Client start reading using positional read api "read(pos, buf[], offset, 
> length)"



--
This message was sent by Atlassian JIRA
(v6.3.15#6346)

---------------------------------------------------------------------
To unsubscribe, e-mail: hdfs-issues-unsubscr...@hadoop.apache.org
For additional commands, e-mail: hdfs-issues-h...@hadoop.apache.org

Reply via email to