HBASE-16284 Unauthorized client can shutdown the cluster
This commit is contained in:
parent
dc56aa2d4f
commit
1b5f8c7123
|
@ -2329,13 +2329,9 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
return rsFatals;
|
return rsFatals;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void shutdown() {
|
public void shutdown() throws IOException {
|
||||||
if (cpHost != null) {
|
if (cpHost != null) {
|
||||||
try {
|
cpHost.preShutdown();
|
||||||
cpHost.preShutdown();
|
|
||||||
} catch (IOException ioe) {
|
|
||||||
LOG.error("Error call master coprocessor preShutdown()", ioe);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.serverManager != null) {
|
if (this.serverManager != null) {
|
||||||
|
@ -2350,13 +2346,9 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void stopMaster() {
|
public void stopMaster() throws IOException {
|
||||||
if (cpHost != null) {
|
if (cpHost != null) {
|
||||||
try {
|
cpHost.preStopMaster();
|
||||||
cpHost.preStopMaster();
|
|
||||||
} catch (IOException ioe) {
|
|
||||||
LOG.error("Error call master coprocessor preStopMaster()", ioe);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
stop("Stopped by " + Thread.currentThread().getName());
|
stop("Stopped by " + Thread.currentThread().getName());
|
||||||
}
|
}
|
||||||
|
|
|
@ -181,6 +181,7 @@ import org.apache.hadoop.hbase.protobuf.generated.RegionServerStatusProtos.Repor
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.RegionServerStatusProtos.ReportRegionStateTransitionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.RegionServerStatusProtos.ReportRegionStateTransitionRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.RegionServerStatusProtos.ReportRegionStateTransitionResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.RegionServerStatusProtos.ReportRegionStateTransitionResponse;
|
||||||
import org.apache.hadoop.hbase.regionserver.RSRpcServices;
|
import org.apache.hadoop.hbase.regionserver.RSRpcServices;
|
||||||
|
import org.apache.hadoop.hbase.security.AccessDeniedException;
|
||||||
import org.apache.hadoop.hbase.security.User;
|
import org.apache.hadoop.hbase.security.User;
|
||||||
import org.apache.hadoop.hbase.security.access.AccessController;
|
import org.apache.hadoop.hbase.security.access.AccessController;
|
||||||
import org.apache.hadoop.hbase.security.visibility.VisibilityController;
|
import org.apache.hadoop.hbase.security.visibility.VisibilityController;
|
||||||
|
@ -1319,7 +1320,12 @@ public class MasterRpcServices extends RSRpcServices
|
||||||
public ShutdownResponse shutdown(RpcController controller,
|
public ShutdownResponse shutdown(RpcController controller,
|
||||||
ShutdownRequest request) throws ServiceException {
|
ShutdownRequest request) throws ServiceException {
|
||||||
LOG.info(master.getClientIdAuditPrefix() + " shutdown");
|
LOG.info(master.getClientIdAuditPrefix() + " shutdown");
|
||||||
master.shutdown();
|
try {
|
||||||
|
master.shutdown();
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOG.error("Exception occurred in HMaster.shutdown()", e);
|
||||||
|
throw new ServiceException(e);
|
||||||
|
}
|
||||||
return ShutdownResponse.newBuilder().build();
|
return ShutdownResponse.newBuilder().build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1356,7 +1362,12 @@ public class MasterRpcServices extends RSRpcServices
|
||||||
public StopMasterResponse stopMaster(RpcController controller,
|
public StopMasterResponse stopMaster(RpcController controller,
|
||||||
StopMasterRequest request) throws ServiceException {
|
StopMasterRequest request) throws ServiceException {
|
||||||
LOG.info(master.getClientIdAuditPrefix() + " stop");
|
LOG.info(master.getClientIdAuditPrefix() + " stop");
|
||||||
master.stopMaster();
|
try {
|
||||||
|
master.stopMaster();
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOG.error("Exception occurred while stopping master", e);
|
||||||
|
throw new ServiceException(e);
|
||||||
|
}
|
||||||
return StopMasterResponse.newBuilder().build();
|
return StopMasterResponse.newBuilder().build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -249,14 +249,23 @@ public class JVMClusterUtil {
|
||||||
JVMClusterUtil.MasterThread activeMaster = null;
|
JVMClusterUtil.MasterThread activeMaster = null;
|
||||||
for (JVMClusterUtil.MasterThread t : masters) {
|
for (JVMClusterUtil.MasterThread t : masters) {
|
||||||
if (!t.master.isActiveMaster()) {
|
if (!t.master.isActiveMaster()) {
|
||||||
t.master.stopMaster();
|
try {
|
||||||
|
t.master.stopMaster();
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOG.error("Exception occurred while stopping master", e);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
activeMaster = t;
|
activeMaster = t;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Do active after.
|
// Do active after.
|
||||||
if (activeMaster != null)
|
if (activeMaster != null) {
|
||||||
activeMaster.master.shutdown();
|
try {
|
||||||
|
activeMaster.master.shutdown();
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOG.error("Exception occurred in HMaster.shutdown()", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
boolean wasInterrupted = false;
|
boolean wasInterrupted = false;
|
||||||
|
|
|
@ -98,6 +98,7 @@ import org.apache.hadoop.hbase.io.hfile.HFileContext;
|
||||||
import org.apache.hadoop.hbase.io.hfile.HFileContextBuilder;
|
import org.apache.hadoop.hbase.io.hfile.HFileContextBuilder;
|
||||||
import org.apache.hadoop.hbase.ipc.protobuf.generated.TestProcedureProtos;
|
import org.apache.hadoop.hbase.ipc.protobuf.generated.TestProcedureProtos;
|
||||||
import org.apache.hadoop.hbase.mapreduce.LoadIncrementalHFiles;
|
import org.apache.hadoop.hbase.mapreduce.LoadIncrementalHFiles;
|
||||||
|
import org.apache.hadoop.hbase.master.HMaster;
|
||||||
import org.apache.hadoop.hbase.master.MasterCoprocessorHost;
|
import org.apache.hadoop.hbase.master.MasterCoprocessorHost;
|
||||||
import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;
|
import org.apache.hadoop.hbase.master.procedure.MasterProcedureEnv;
|
||||||
import org.apache.hadoop.hbase.master.procedure.TableProcedureInterface;
|
import org.apache.hadoop.hbase.master.procedure.TableProcedureInterface;
|
||||||
|
@ -332,6 +333,33 @@ public class TestAccessController extends SecureTestUtil {
|
||||||
TEST_TABLE.getNamespaceAsString()).size());
|
TEST_TABLE.getNamespaceAsString()).size());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test (timeout=180000)
|
||||||
|
public void testUnauthorizedShutdown() throws Exception {
|
||||||
|
AccessTestAction action = new AccessTestAction() {
|
||||||
|
@Override public Object run() throws Exception {
|
||||||
|
HMaster master = TEST_UTIL.getHBaseCluster().getMaster();
|
||||||
|
master.shutdown();
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
verifyDenied(action, USER_CREATE, USER_OWNER, USER_RW, USER_RO, USER_NONE, USER_GROUP_READ,
|
||||||
|
USER_GROUP_WRITE, USER_GROUP_CREATE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test (timeout=180000)
|
||||||
|
public void testUnauthorizedStopMaster() throws Exception {
|
||||||
|
AccessTestAction action = new AccessTestAction() {
|
||||||
|
@Override public Object run() throws Exception {
|
||||||
|
HMaster master = TEST_UTIL.getHBaseCluster().getMaster();
|
||||||
|
master.stopMaster();
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
verifyDenied(action, USER_CREATE, USER_OWNER, USER_RW, USER_RO, USER_NONE, USER_GROUP_READ,
|
||||||
|
USER_GROUP_WRITE, USER_GROUP_CREATE);
|
||||||
|
}
|
||||||
|
|
||||||
@Test (timeout=180000)
|
@Test (timeout=180000)
|
||||||
public void testSecurityCapabilities() throws Exception {
|
public void testSecurityCapabilities() throws Exception {
|
||||||
List<SecurityCapability> capabilities = TEST_UTIL.getConnection().getAdmin()
|
List<SecurityCapability> capabilities = TEST_UTIL.getConnection().getAdmin()
|
||||||
|
|
Loading…
Reference in New Issue