[
https://issues.apache.org/jira/browse/HBASE-28683?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Duo Zhang reassigned HBASE-28683:
---------------------------------
Assignee: Duo Zhang
> Only allow one TableProcedureInterface for a single table to run at the same
> time for some special procedure types
> ------------------------------------------------------------------------------------------------------------------
>
> Key: HBASE-28683
> URL: https://issues.apache.org/jira/browse/HBASE-28683
> Project: HBase
> Issue Type: Improvement
> Components: master, proc-v2
> Reporter: Duo Zhang
> Assignee: Duo Zhang
> Priority: Critical
>
> We have a table lock in the MasterProcedureScheduler, which is designed to
> only allow one procedure to run at the same time when they require exclusive
> lock.
> But there is a problem that for availability, usually we can not always hold
> the exclusive lock through the whole procedure life time, as if so, we can
> not execute region assignment for this table too. The solution is to set
> holdLock to false, which means we will release the table lock after one
> execution cycle.
> In this way, it is possible that different table procedures may execute at
> the same time, which could mess things up.
> Especially that, in HBASE-28522, we find out that it is even impossible for
> DisableTableProcedure to hold the exclusive lock all the time. If the steps
> for DisableTableProcedure can be overlapped with other procedures like
> ModifyTableProcedure or even EnableTableProcedure, things will be
> definationly messed up...
> So we need to find another way to ensure that for a single table, only one of
> these procedures can be executed at the same time.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)