You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@hbase.apache.org by "stack (JIRA)" <ji...@apache.org> on 2018/03/29 17:43:00 UTC

[jira] [Comment Edited] (HBASE-20229) ConnectionImplementation.locateRegions() returns duplicated entries when region replication is on

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

stack edited comment on HBASE-20229 at 3/29/18 5:42 PM:
--------------------------------------------------------

Resolving. Created a subtask for backport to branch-1. Thanks all. HBASE-20316 is subtask.


was (Author: stack):
Resolving. Created a subtask for backport to branch-1. Thanks all.

> ConnectionImplementation.locateRegions() returns duplicated entries when region replication is on
> -------------------------------------------------------------------------------------------------
>
>                 Key: HBASE-20229
>                 URL: https://issues.apache.org/jira/browse/HBASE-20229
>             Project: HBase
>          Issue Type: Bug
>            Reporter: Toshihiro Suzuki
>            Assignee: Toshihiro Suzuki
>            Priority: Major
>             Fix For: 2.0.0
>
>         Attachments: HBASE-20229.branch-1.001.patch, HBASE-20229.branch-1.002.patch, HBASE-20229.branch-1.002.patch, HBASE-20229.master.001.patch, HBASE-20229.master.002.patch, HBASE-20229.master.003.patch, HBASE-20229.master.004.patch
>
>
> The issue is when region replication is on, ConnectionImplementation.locateRegions() returns duplicated entries.
> In the test in my patch, the table should have 1 primary region + 2 secondaries, but ConnectionImplementation.locateRegions() returns 9 regions. Every region repeats 3 times (3 = replicas count).
> I think this is because the following code calls locateRegion() even for replica regions and then the result triples.
> {code:java}
>     for (RegionInfo regionInfo : regions) {
>       RegionLocations list = locateRegion(tableName, regionInfo.getStartKey(), useCache, true);
>       if (list != null) {
>         for (HRegionLocation loc : list.getRegionLocations()) {
>           if (loc != null) {
>             locations.add(loc);
>           }
>         }
>       }
> {code}
> The fix in my patch is to make it call locateRegion() only for a primary region.



--
This message was sent by Atlassian JIRA
(v7.6.3#76005)