Andrey Stepachev created HBASE-13061:
----------------------------------------
Summary: RegionStates can remove wrong region from server holdings
Key: HBASE-13061
URL: https://issues.apache.org/jira/browse/HBASE-13061
Project: HBase
Issue Type: Bug
Components: Region Assignment
Affects Versions: 1.0.0, 2.0.0
Reporter: Andrey Stepachev
Assignee: Andrey Stepachev
Got failed test in HBASE-13017. It seems that with zk nodes were ordered in one
way and test didn't trigger error, but with new meta rows ordered differently
test became flakey.
That leads to interesting sequence of offline/online regions and triggers bug
and NPE in AM (thats seen in TestZKLessAMOnCluster)
That can happen if region was moved from RS1 to other region server RS2, and
thats happens that RS2 failed. Region remains in PENDING_OPEN. SSH will offline
it from RS1(without removing from oldAssignments because of disabled table).
When AssingnmentManager come and assign region it then removes oldAssignment of
region from serverHoldings. And thats happen to be our just assigned RS1.
Small bit of code.
{code}
2015-02-18 01:21:18,338 INFO [Thread-436] master.RegionStates(1109):
Transition {b73fe9f1185361e846b0e1ceb7d6d64e state=PENDING_OPEN,
ts=1424222478324, server=octobook.home,65370,1424222474885} to
{b73fe9f1185361e846b0e1ceb7d6d64e state=OFFLINE, ts=1424222478338,
server=octobook.home,65370,1424222474885}
2015-02-18 01:21:18,339 INFO [Thread-436] master.RegionStateStore(218):
Updating row
testSSHWhenDisablingTableRegionsInOpeningOrPendingOpenState,I,1424222477651.b73fe9f1185361e846b0e1ceb7d6d64e.
with state=OFFLINE
2015-02-18 01:21:18,340 DEBUG [Thread-436] master.RegionStates(591): Old server
name for {ENCODED => b73fe9f1185361e846b0e1ceb7d6d64e, NAME =>
'testSSHWhenDisablingTableRegionsInOpeningOrPendingOpenState,I,1424222477651.b73fe9f1185361e846b0e1ceb7d6d64e.',
STARTKEY => 'I', ENDKEY => 'Q'} is null
2015-02-18 01:21:18,340 INFO [Thread-436] master.RegionStates(1109):
Transition {b73fe9f1185361e846b0e1ceb7d6d64e state=OFFLINE, ts=1424222478338,
server=octobook.home,65370,1424222474885} to {b73fe9f1185361e846b0e1ceb7d6d64e
state=OPEN, ts=1424222478340, server=octobook.home,65359,1424222474743}
2015-02-18 01:21:18,341 INFO [Thread-436] master.RegionStateStore(218):
Updating row
testSSHWhenDisablingTableRegionsInOpeningOrPendingOpenState,I,1424222477651.b73fe9f1185361e846b0e1ceb7d6d64e.
with state=OPEN&sn=octobook.home,65359,1424222474743
2015-02-18 01:21:18,342 DEBUG [Thread-436] master.RegionStates(457): Onlined
b73fe9f1185361e846b0e1ceb7d6d64e on octobook.home,65359,1424222474743 {ENCODED
=> b73fe9f1185361e846b0e1ceb7d6d64e, NAME =>
'testSSHWhenDisablingTableRegionsInOpeningOrPendingOpenState,I,1424222477651.b73fe9f1185361e846b0e1ceb7d6d64e.',
STARTKEY => 'I', ENDKEY => 'Q'}
2015-02-18 01:21:18,342 DEBUG [Thread-436] master.RegionStates(481): Adding
b73fe9f1185361e846b0e1ceb7d6d64e to server octobook.home,65359,1424222474743
2015-02-18 01:21:18,342 INFO [Thread-436] master.RegionStates(467): Offlined
b73fe9f1185361e846b0e1ceb7d6d64e from octobook.home,65359,1424222474743
2015-02-18 01:21:18,342 DEBUG [Thread-436] master.RegionStates(496): Removing
b73fe9f1185361e846b0e1ceb7d6d64e from server octobook.home,65359,1424222474743
2015-02-18 01:21:18,347 INFO [Thread-436] hbase.MetaTableAccessor(1437):
Updated table testSSHWhenDisablingTableRegionsInOpeningOrPendingOpenState state
to DISABLED in META
{code}
--
This message was sent by Atlassian JIRA
(v6.3.4#6332)