[jira] [Updated] (HDFS-5828) BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same node group when dfs.namenode.avoid.write.stale.datanode is true

2014-02-02 Thread Junping Du (JIRA)

 [ 
https://issues.apache.org/jira/browse/HDFS-5828?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Junping Du updated HDFS-5828:
-

   Resolution: Fixed
Fix Version/s: 2.4.0
   Status: Resolved  (was: Patch Available)

Commit patch to trunk and branch-2. Thanks Buddy for the work!

 BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same 
 node group when dfs.namenode.avoid.write.stale.datanode is true
 -

 Key: HDFS-5828
 URL: https://issues.apache.org/jira/browse/HDFS-5828
 Project: Hadoop HDFS
  Issue Type: Bug
  Components: namenode
Affects Versions: 2.3.0
Reporter: Buddy
 Fix For: 2.4.0

 Attachments: HDFS-5828.patch, HDFS-5828a.patch


 When placing replicas using the replica placement policy 
 BlockPlacementPolicyWithNodeGroup, the number of targets returned should be 
 less than or equal to the number of node groups and no node group should get 
 two replicas of the same block. The Junit test 
 TestReplicationPolicyWithNodeGroup.testChooseMoreTargetsThanNodeGroups 
 verifies this.
 However, if the conf property dfs.namenode.avoid.write.stale.datanode is 
 set to true, then block placement policy will return more targets than node 
 groups when the number of replicas requested exceeds the number of node 
 groups.
 This can be seen by putting:
CONF.setBoolean(DFS_NAMENODE_AVOID_STALE_DATANODE_FOR_WRITE_KEY, true);
 in the setup method for TestReplicationPolicyWithNodeGroup. This will cause 
 testChooseMoreTargetsThanNodeGroups to fail.



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)


[jira] [Updated] (HDFS-5828) BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same node group when dfs.namenode.avoid.write.stale.datanode is true

2014-02-02 Thread Tsz Wo (Nicholas), SZE (JIRA)

 [ 
https://issues.apache.org/jira/browse/HDFS-5828?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Tsz Wo (Nicholas), SZE updated HDFS-5828:
-

Assignee: Buddy
Hadoop Flags: Reviewed

Buddy and Junping, thanks a lot for working on this!

 BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same 
 node group when dfs.namenode.avoid.write.stale.datanode is true
 -

 Key: HDFS-5828
 URL: https://issues.apache.org/jira/browse/HDFS-5828
 Project: Hadoop HDFS
  Issue Type: Bug
  Components: namenode
Affects Versions: 2.3.0
Reporter: Buddy
Assignee: Buddy
 Fix For: 2.4.0

 Attachments: HDFS-5828.patch, HDFS-5828a.patch


 When placing replicas using the replica placement policy 
 BlockPlacementPolicyWithNodeGroup, the number of targets returned should be 
 less than or equal to the number of node groups and no node group should get 
 two replicas of the same block. The Junit test 
 TestReplicationPolicyWithNodeGroup.testChooseMoreTargetsThanNodeGroups 
 verifies this.
 However, if the conf property dfs.namenode.avoid.write.stale.datanode is 
 set to true, then block placement policy will return more targets than node 
 groups when the number of replicas requested exceeds the number of node 
 groups.
 This can be seen by putting:
CONF.setBoolean(DFS_NAMENODE_AVOID_STALE_DATANODE_FOR_WRITE_KEY, true);
 in the setup method for TestReplicationPolicyWithNodeGroup. This will cause 
 testChooseMoreTargetsThanNodeGroups to fail.



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)


[jira] [Updated] (HDFS-5828) BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same node group when dfs.namenode.avoid.write.stale.datanode is true

2014-02-01 Thread Junping Du (JIRA)

 [ 
https://issues.apache.org/jira/browse/HDFS-5828?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Junping Du updated HDFS-5828:
-

Status: Patch Available  (was: Open)

 BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same 
 node group when dfs.namenode.avoid.write.stale.datanode is true
 -

 Key: HDFS-5828
 URL: https://issues.apache.org/jira/browse/HDFS-5828
 Project: Hadoop HDFS
  Issue Type: Bug
  Components: namenode
Affects Versions: 2.3.0
Reporter: Buddy
 Attachments: HDFS-5828.patch, HDFS-5828a.patch


 When placing replicas using the replica placement policy 
 BlockPlacementPolicyWithNodeGroup, the number of targets returned should be 
 less than or equal to the number of node groups and no node group should get 
 two replicas of the same block. The Junit test 
 TestReplicationPolicyWithNodeGroup.testChooseMoreTargetsThanNodeGroups 
 verifies this.
 However, if the conf property dfs.namenode.avoid.write.stale.datanode is 
 set to true, then block placement policy will return more targets than node 
 groups when the number of replicas requested exceeds the number of node 
 groups.
 This can be seen by putting:
CONF.setBoolean(DFS_NAMENODE_AVOID_STALE_DATANODE_FOR_WRITE_KEY, true);
 in the setup method for TestReplicationPolicyWithNodeGroup. This will cause 
 testChooseMoreTargetsThanNodeGroups to fail.



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)


[jira] [Updated] (HDFS-5828) BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same node group when dfs.namenode.avoid.write.stale.datanode is true

2014-01-31 Thread Buddy (JIRA)

 [ 
https://issues.apache.org/jira/browse/HDFS-5828?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Buddy updated HDFS-5828:


Attachment: HDFS-5828a.patch

Good point. I made the change and uploaded a new patch.
Thanks Junping.



 BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same 
 node group when dfs.namenode.avoid.write.stale.datanode is true
 -

 Key: HDFS-5828
 URL: https://issues.apache.org/jira/browse/HDFS-5828
 Project: Hadoop HDFS
  Issue Type: Bug
  Components: namenode
Affects Versions: 2.3.0
Reporter: Buddy
 Attachments: HDFS-5828.patch, HDFS-5828a.patch


 When placing replicas using the replica placement policy 
 BlockPlacementPolicyWithNodeGroup, the number of targets returned should be 
 less than or equal to the number of node groups and no node group should get 
 two replicas of the same block. The Junit test 
 TestReplicationPolicyWithNodeGroup.testChooseMoreTargetsThanNodeGroups 
 verifies this.
 However, if the conf property dfs.namenode.avoid.write.stale.datanode is 
 set to true, then block placement policy will return more targets than node 
 groups when the number of replicas requested exceeds the number of node 
 groups.
 This can be seen by putting:
CONF.setBoolean(DFS_NAMENODE_AVOID_STALE_DATANODE_FOR_WRITE_KEY, true);
 in the setup method for TestReplicationPolicyWithNodeGroup. This will cause 
 testChooseMoreTargetsThanNodeGroups to fail.



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)


[jira] [Updated] (HDFS-5828) BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same node group when dfs.namenode.avoid.write.stale.datanode is true

2014-01-28 Thread Buddy (JIRA)

 [ 
https://issues.apache.org/jira/browse/HDFS-5828?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Buddy updated HDFS-5828:


Attachment: HDFS-5828.patch

The problem was BlockPlacementPolicyDefault.chooseTarget was manually adding 
the nodes in the results list to the excluded nodes list instead of using the 
addToExcludedNodes method. 

The addToExcludedNodes method is overridden by 
BlockPlacementPolicyWithNodeGroup to also exclude other nodes in the same node 
group.


 BlockPlacementPolicyWithNodeGroup can place multiple replicas on the same 
 node group when dfs.namenode.avoid.write.stale.datanode is true
 -

 Key: HDFS-5828
 URL: https://issues.apache.org/jira/browse/HDFS-5828
 Project: Hadoop HDFS
  Issue Type: Bug
  Components: namenode
Affects Versions: 2.4.0
Reporter: Buddy
 Attachments: HDFS-5828.patch


 When placing replicas using the replica placement policy 
 BlockPlacementPolicyWithNodeGroup, the number of targets returned should be 
 less than or equal to the number of node groups and no node group should get 
 two replicas of the same block. The Junit test 
 TestReplicationPolicyWithNodeGroup.testChooseMoreTargetsThanNodeGroups 
 verifies this.
 However, if the conf property dfs.namenode.avoid.write.stale.datanode is 
 set to true, then block placement policy will return more targets than node 
 groups when the number of replicas requested exceeds the number of node 
 groups.
 This can be seen by putting:
CONF.setBoolean(DFS_NAMENODE_AVOID_STALE_DATANODE_FOR_WRITE_KEY, true);
 in the setup method for TestReplicationPolicyWithNodeGroup. This will cause 
 testChooseMoreTargetsThanNodeGroups to fail.



--
This message was sent by Atlassian JIRA
(v6.1.5#6160)