HBASE-14367 Add normalization support to shell
This commit is contained in:
parent
5f95ec6265
commit
b9bfd6f7e3
|
@ -264,6 +264,7 @@ public class HTableDescriptor implements WritableComparable<HTableDescriptor> {
|
||||||
String.valueOf(DEFAULT_DEFERRED_LOG_FLUSH));
|
String.valueOf(DEFAULT_DEFERRED_LOG_FLUSH));
|
||||||
DEFAULT_VALUES.put(DURABILITY, DEFAULT_DURABLITY.name()); //use the enum name
|
DEFAULT_VALUES.put(DURABILITY, DEFAULT_DURABLITY.name()); //use the enum name
|
||||||
DEFAULT_VALUES.put(REGION_REPLICATION, String.valueOf(DEFAULT_REGION_REPLICATION));
|
DEFAULT_VALUES.put(REGION_REPLICATION, String.valueOf(DEFAULT_REGION_REPLICATION));
|
||||||
|
DEFAULT_VALUES.put(NORMALIZATION_ENABLED, String.valueOf(DEFAULT_NORMALIZATION_ENABLED));
|
||||||
for (String s : DEFAULT_VALUES.keySet()) {
|
for (String s : DEFAULT_VALUES.keySet()) {
|
||||||
RESERVED_KEYWORDS.add(new ImmutableBytesWritable(Bytes.toBytes(s)));
|
RESERVED_KEYWORDS.add(new ImmutableBytesWritable(Bytes.toBytes(s)));
|
||||||
}
|
}
|
||||||
|
|
|
@ -722,6 +722,28 @@ public interface Admin extends Abortable, Closeable {
|
||||||
*/
|
*/
|
||||||
boolean isBalancerEnabled() throws IOException;
|
boolean isBalancerEnabled() throws IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Invoke region normalizer. Can NOT run for various reasons. Check logs.
|
||||||
|
*
|
||||||
|
* @return True if region normalizer ran, false otherwise.
|
||||||
|
*/
|
||||||
|
boolean normalize() throws IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Query the current state of the region normalizer
|
||||||
|
*
|
||||||
|
* @return true if region normalizer is enabled, false otherwise.
|
||||||
|
*/
|
||||||
|
boolean isNormalizerEnabled() throws IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn region normalizer on or off.
|
||||||
|
*
|
||||||
|
* @return Previous normalizer value
|
||||||
|
*/
|
||||||
|
boolean setNormalizerRunning(final boolean on)
|
||||||
|
throws IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enable/Disable the catalog janitor
|
* Enable/Disable the catalog janitor
|
||||||
*
|
*
|
||||||
|
|
|
@ -128,6 +128,8 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorE
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorEnabledResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorEnabledResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningResponse;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsNormalizerEnabledRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsNormalizerEnabledResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsRestoreSnapshotDoneRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsRestoreSnapshotDoneRequest;
|
||||||
|
@ -152,6 +154,8 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableReques
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionResponse;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.NormalizeRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.NormalizeResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RestoreSnapshotRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RestoreSnapshotRequest;
|
||||||
|
@ -162,6 +166,8 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilit
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilitiesResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilitiesResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningResponse;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetNormalizerRunningRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetNormalizerRunningResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ShutdownRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ShutdownRequest;
|
||||||
|
@ -1846,6 +1852,19 @@ class ConnectionManager {
|
||||||
return stub.setBalancerRunning(controller, request);
|
return stub.setBalancerRunning(controller, request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NormalizeResponse normalize(RpcController controller,
|
||||||
|
NormalizeRequest request) throws ServiceException {
|
||||||
|
return stub.normalize(controller, request);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SetNormalizerRunningResponse setNormalizerRunning(
|
||||||
|
RpcController controller, SetNormalizerRunningRequest request)
|
||||||
|
throws ServiceException {
|
||||||
|
return stub.setNormalizerRunning(controller, request);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public RunCatalogScanResponse runCatalogScan(RpcController controller,
|
public RunCatalogScanResponse runCatalogScan(RpcController controller,
|
||||||
RunCatalogScanRequest request) throws ServiceException {
|
RunCatalogScanRequest request) throws ServiceException {
|
||||||
|
@ -2049,6 +2068,12 @@ class ConnectionManager {
|
||||||
return stub.isBalancerEnabled(controller, request);
|
return stub.isBalancerEnabled(controller, request);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public IsNormalizerEnabledResponse isNormalizerEnabled(RpcController controller,
|
||||||
|
IsNormalizerEnabledRequest request) throws ServiceException {
|
||||||
|
return stub.isNormalizerEnabled(controller, request);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public SecurityCapabilitiesResponse getSecurityCapabilities(RpcController controller,
|
public SecurityCapabilitiesResponse getSecurityCapabilities(RpcController controller,
|
||||||
SecurityCapabilitiesRequest request) throws ServiceException {
|
SecurityCapabilitiesRequest request) throws ServiceException {
|
||||||
|
|
|
@ -142,6 +142,7 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RestoreSnapshotRe
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RestoreSnapshotResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RestoreSnapshotResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilitiesRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilitiesRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetNormalizerRunningRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ShutdownRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ShutdownRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SnapshotRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SnapshotRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SnapshotResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SnapshotResponse;
|
||||||
|
@ -2337,6 +2338,53 @@ public class HBaseAdmin implements Admin {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Invoke region normalizer. Can NOT run for various reasons. Check logs.
|
||||||
|
*
|
||||||
|
* @return True if region normalizer ran, false otherwise.
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean normalize() throws IOException {
|
||||||
|
return executeCallable(new MasterCallable<Boolean>(getConnection()) {
|
||||||
|
@Override
|
||||||
|
public Boolean call(int callTimeout) throws ServiceException {
|
||||||
|
return master.normalize(null,
|
||||||
|
RequestConverter.buildNormalizeRequest()).getNormalizerRan();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Query the current state of the region normalizer
|
||||||
|
*
|
||||||
|
* @return true if region normalizer is enabled, false otherwise.
|
||||||
|
*/
|
||||||
|
public boolean isNormalizerEnabled() throws IOException {
|
||||||
|
return executeCallable(new MasterCallable<Boolean>(getConnection()) {
|
||||||
|
@Override
|
||||||
|
public Boolean call(int callTimeout) throws ServiceException {
|
||||||
|
return master.isNormalizerEnabled(null,
|
||||||
|
RequestConverter.buildIsNormalizerEnabledRequest()).getEnabled();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn region normalizer on or off.
|
||||||
|
*
|
||||||
|
* @return Previous normalizer value
|
||||||
|
*/
|
||||||
|
public boolean setNormalizerRunning(final boolean on) throws IOException {
|
||||||
|
return executeCallable(new MasterCallable<Boolean>(getConnection()) {
|
||||||
|
@Override
|
||||||
|
public Boolean call(int callTimeout) throws ServiceException {
|
||||||
|
SetNormalizerRunningRequest req =
|
||||||
|
RequestConverter.buildSetNormalizerRunningRequest(on);
|
||||||
|
return master.setNormalizerRunning(null, req).getPrevNormalizerValue();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enable/Disable the catalog janitor
|
* Enable/Disable the catalog janitor
|
||||||
* @param enable if true enables the catalog janitor
|
* @param enable if true enables the catalog janitor
|
||||||
|
|
|
@ -96,12 +96,15 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.GetTableNamesRequ
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsBalancerEnabledRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsBalancerEnabledRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorEnabledRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorEnabledRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsNormalizerEnabledRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyColumnRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyColumnRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.NormalizeRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RunCatalogScanRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RunCatalogScanRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetNormalizerRunningRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.TruncateTableRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.TruncateTableRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.UnassignRegionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.UnassignRegionRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.RegionServerStatusProtos.GetLastFlushedSequenceIdRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.RegionServerStatusProtos.GetLastFlushedSequenceIdRequest;
|
||||||
|
@ -1691,4 +1694,32 @@ public final class RequestConverter {
|
||||||
}
|
}
|
||||||
return builder.build();
|
return builder.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a protocol buffer NormalizeRequest
|
||||||
|
*
|
||||||
|
* @return a NormalizeRequest
|
||||||
|
*/
|
||||||
|
public static NormalizeRequest buildNormalizeRequest() {
|
||||||
|
return NormalizeRequest.newBuilder().build();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a protocol buffer IsNormalizerEnabledRequest
|
||||||
|
*
|
||||||
|
* @return a IsNormalizerEnabledRequest
|
||||||
|
*/
|
||||||
|
public static IsNormalizerEnabledRequest buildIsNormalizerEnabledRequest() {
|
||||||
|
return IsNormalizerEnabledRequest.newBuilder().build();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a protocol buffer SetNormalizerRunningRequest
|
||||||
|
*
|
||||||
|
* @param on
|
||||||
|
* @return a SetNormalizerRunningRequest
|
||||||
|
*/
|
||||||
|
public static SetNormalizerRunningRequest buildSetNormalizerRunningRequest(boolean on) {
|
||||||
|
return SetNormalizerRunningRequest.newBuilder().setOn(on).build();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -111,6 +111,8 @@ public class ZooKeeperWatcher implements Watcher, Abortable, Closeable {
|
||||||
public String splitLogZNode;
|
public String splitLogZNode;
|
||||||
// znode containing the state of the load balancer
|
// znode containing the state of the load balancer
|
||||||
public String balancerZNode;
|
public String balancerZNode;
|
||||||
|
// znode containing the state of region normalizer
|
||||||
|
private String regionNormalizerZNode;
|
||||||
// znode containing the lock for the tables
|
// znode containing the lock for the tables
|
||||||
public String tableLockZNode;
|
public String tableLockZNode;
|
||||||
// znode containing the state of recovering regions
|
// znode containing the state of recovering regions
|
||||||
|
@ -351,6 +353,8 @@ public class ZooKeeperWatcher implements Watcher, Abortable, Closeable {
|
||||||
conf.get("zookeeper.znode.splitlog", HConstants.SPLIT_LOGDIR_NAME));
|
conf.get("zookeeper.znode.splitlog", HConstants.SPLIT_LOGDIR_NAME));
|
||||||
balancerZNode = ZKUtil.joinZNode(baseZNode,
|
balancerZNode = ZKUtil.joinZNode(baseZNode,
|
||||||
conf.get("zookeeper.znode.balancer", "balancer"));
|
conf.get("zookeeper.znode.balancer", "balancer"));
|
||||||
|
regionNormalizerZNode = ZKUtil.joinZNode(baseZNode,
|
||||||
|
conf.get("zookeeper.znode.regionNormalizer", "normalizer"));
|
||||||
tableLockZNode = ZKUtil.joinZNode(baseZNode,
|
tableLockZNode = ZKUtil.joinZNode(baseZNode,
|
||||||
conf.get("zookeeper.znode.tableLock", "table-lock"));
|
conf.get("zookeeper.znode.tableLock", "table-lock"));
|
||||||
recoveringRegionsZNode = ZKUtil.joinZNode(baseZNode,
|
recoveringRegionsZNode = ZKUtil.joinZNode(baseZNode,
|
||||||
|
@ -704,4 +708,10 @@ public class ZooKeeperWatcher implements Watcher, Abortable, Closeable {
|
||||||
return this.masterAddressZNode;
|
return this.masterAddressZNode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return ZooKeeper znode for region normalizer state
|
||||||
|
*/
|
||||||
|
public String getRegionNormalizerZNode() {
|
||||||
|
return regionNormalizerZNode;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,6 +47,7 @@ public class TestZooKeeperWatcher {
|
||||||
|
|
||||||
assertFalse(watcher.isClientReadable(watcher.tableLockZNode));
|
assertFalse(watcher.isClientReadable(watcher.tableLockZNode));
|
||||||
assertFalse(watcher.isClientReadable(watcher.balancerZNode));
|
assertFalse(watcher.isClientReadable(watcher.balancerZNode));
|
||||||
|
assertFalse(watcher.isClientReadable(watcher.getRegionNormalizerZNode()));
|
||||||
assertFalse(watcher.isClientReadable(watcher.clusterStateZNode));
|
assertFalse(watcher.isClientReadable(watcher.clusterStateZNode));
|
||||||
assertFalse(watcher.isClientReadable(watcher.drainingZNode));
|
assertFalse(watcher.isClientReadable(watcher.drainingZNode));
|
||||||
assertFalse(watcher.isClientReadable(watcher.recoveringRegionsZNode));
|
assertFalse(watcher.isClientReadable(watcher.recoveringRegionsZNode));
|
||||||
|
|
|
@ -189,6 +189,7 @@
|
||||||
<include>MultiRowMutation.proto</include>
|
<include>MultiRowMutation.proto</include>
|
||||||
<include>Procedure.proto</include>
|
<include>Procedure.proto</include>
|
||||||
<include>Quota.proto</include>
|
<include>Quota.proto</include>
|
||||||
|
<include>RegionNormalizer.proto</include>
|
||||||
<include>RegionServerStatus.proto</include>
|
<include>RegionServerStatus.proto</include>
|
||||||
<include>RowProcessor.proto</include>
|
<include>RowProcessor.proto</include>
|
||||||
<include>RPC.proto</include>
|
<include>RPC.proto</include>
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,485 @@
|
||||||
|
// Generated by the protocol buffer compiler. DO NOT EDIT!
|
||||||
|
// source: RegionNormalizer.proto
|
||||||
|
|
||||||
|
package org.apache.hadoop.hbase.protobuf.generated;
|
||||||
|
|
||||||
|
public final class RegionNormalizerProtos {
|
||||||
|
private RegionNormalizerProtos() {}
|
||||||
|
public static void registerAllExtensions(
|
||||||
|
com.google.protobuf.ExtensionRegistry registry) {
|
||||||
|
}
|
||||||
|
public interface RegionNormalizerStateOrBuilder
|
||||||
|
extends com.google.protobuf.MessageOrBuilder {
|
||||||
|
|
||||||
|
// optional bool normalizer_on = 1;
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
boolean hasNormalizerOn();
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
boolean getNormalizerOn();
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Protobuf type {@code RegionNormalizerState}
|
||||||
|
*/
|
||||||
|
public static final class RegionNormalizerState extends
|
||||||
|
com.google.protobuf.GeneratedMessage
|
||||||
|
implements RegionNormalizerStateOrBuilder {
|
||||||
|
// Use RegionNormalizerState.newBuilder() to construct.
|
||||||
|
private RegionNormalizerState(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
|
||||||
|
super(builder);
|
||||||
|
this.unknownFields = builder.getUnknownFields();
|
||||||
|
}
|
||||||
|
private RegionNormalizerState(boolean noInit) { this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance(); }
|
||||||
|
|
||||||
|
private static final RegionNormalizerState defaultInstance;
|
||||||
|
public static RegionNormalizerState getDefaultInstance() {
|
||||||
|
return defaultInstance;
|
||||||
|
}
|
||||||
|
|
||||||
|
public RegionNormalizerState getDefaultInstanceForType() {
|
||||||
|
return defaultInstance;
|
||||||
|
}
|
||||||
|
|
||||||
|
private final com.google.protobuf.UnknownFieldSet unknownFields;
|
||||||
|
@java.lang.Override
|
||||||
|
public final com.google.protobuf.UnknownFieldSet
|
||||||
|
getUnknownFields() {
|
||||||
|
return this.unknownFields;
|
||||||
|
}
|
||||||
|
private RegionNormalizerState(
|
||||||
|
com.google.protobuf.CodedInputStream input,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws com.google.protobuf.InvalidProtocolBufferException {
|
||||||
|
initFields();
|
||||||
|
int mutable_bitField0_ = 0;
|
||||||
|
com.google.protobuf.UnknownFieldSet.Builder unknownFields =
|
||||||
|
com.google.protobuf.UnknownFieldSet.newBuilder();
|
||||||
|
try {
|
||||||
|
boolean done = false;
|
||||||
|
while (!done) {
|
||||||
|
int tag = input.readTag();
|
||||||
|
switch (tag) {
|
||||||
|
case 0:
|
||||||
|
done = true;
|
||||||
|
break;
|
||||||
|
default: {
|
||||||
|
if (!parseUnknownField(input, unknownFields,
|
||||||
|
extensionRegistry, tag)) {
|
||||||
|
done = true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 8: {
|
||||||
|
bitField0_ |= 0x00000001;
|
||||||
|
normalizerOn_ = input.readBool();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (com.google.protobuf.InvalidProtocolBufferException e) {
|
||||||
|
throw e.setUnfinishedMessage(this);
|
||||||
|
} catch (java.io.IOException e) {
|
||||||
|
throw new com.google.protobuf.InvalidProtocolBufferException(
|
||||||
|
e.getMessage()).setUnfinishedMessage(this);
|
||||||
|
} finally {
|
||||||
|
this.unknownFields = unknownFields.build();
|
||||||
|
makeExtensionsImmutable();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static final com.google.protobuf.Descriptors.Descriptor
|
||||||
|
getDescriptor() {
|
||||||
|
return org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.internal_static_RegionNormalizerState_descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
|
||||||
|
internalGetFieldAccessorTable() {
|
||||||
|
return org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.internal_static_RegionNormalizerState_fieldAccessorTable
|
||||||
|
.ensureFieldAccessorsInitialized(
|
||||||
|
org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState.class, org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState.Builder.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static com.google.protobuf.Parser<RegionNormalizerState> PARSER =
|
||||||
|
new com.google.protobuf.AbstractParser<RegionNormalizerState>() {
|
||||||
|
public RegionNormalizerState parsePartialFrom(
|
||||||
|
com.google.protobuf.CodedInputStream input,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws com.google.protobuf.InvalidProtocolBufferException {
|
||||||
|
return new RegionNormalizerState(input, extensionRegistry);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
@java.lang.Override
|
||||||
|
public com.google.protobuf.Parser<RegionNormalizerState> getParserForType() {
|
||||||
|
return PARSER;
|
||||||
|
}
|
||||||
|
|
||||||
|
private int bitField0_;
|
||||||
|
// optional bool normalizer_on = 1;
|
||||||
|
public static final int NORMALIZER_ON_FIELD_NUMBER = 1;
|
||||||
|
private boolean normalizerOn_;
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
public boolean hasNormalizerOn() {
|
||||||
|
return ((bitField0_ & 0x00000001) == 0x00000001);
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
public boolean getNormalizerOn() {
|
||||||
|
return normalizerOn_;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void initFields() {
|
||||||
|
normalizerOn_ = false;
|
||||||
|
}
|
||||||
|
private byte memoizedIsInitialized = -1;
|
||||||
|
public final boolean isInitialized() {
|
||||||
|
byte isInitialized = memoizedIsInitialized;
|
||||||
|
if (isInitialized != -1) return isInitialized == 1;
|
||||||
|
|
||||||
|
memoizedIsInitialized = 1;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void writeTo(com.google.protobuf.CodedOutputStream output)
|
||||||
|
throws java.io.IOException {
|
||||||
|
getSerializedSize();
|
||||||
|
if (((bitField0_ & 0x00000001) == 0x00000001)) {
|
||||||
|
output.writeBool(1, normalizerOn_);
|
||||||
|
}
|
||||||
|
getUnknownFields().writeTo(output);
|
||||||
|
}
|
||||||
|
|
||||||
|
private int memoizedSerializedSize = -1;
|
||||||
|
public int getSerializedSize() {
|
||||||
|
int size = memoizedSerializedSize;
|
||||||
|
if (size != -1) return size;
|
||||||
|
|
||||||
|
size = 0;
|
||||||
|
if (((bitField0_ & 0x00000001) == 0x00000001)) {
|
||||||
|
size += com.google.protobuf.CodedOutputStream
|
||||||
|
.computeBoolSize(1, normalizerOn_);
|
||||||
|
}
|
||||||
|
size += getUnknownFields().getSerializedSize();
|
||||||
|
memoizedSerializedSize = size;
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final long serialVersionUID = 0L;
|
||||||
|
@java.lang.Override
|
||||||
|
protected java.lang.Object writeReplace()
|
||||||
|
throws java.io.ObjectStreamException {
|
||||||
|
return super.writeReplace();
|
||||||
|
}
|
||||||
|
|
||||||
|
@java.lang.Override
|
||||||
|
public boolean equals(final java.lang.Object obj) {
|
||||||
|
if (obj == this) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!(obj instanceof org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState)) {
|
||||||
|
return super.equals(obj);
|
||||||
|
}
|
||||||
|
org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState other = (org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState) obj;
|
||||||
|
|
||||||
|
boolean result = true;
|
||||||
|
result = result && (hasNormalizerOn() == other.hasNormalizerOn());
|
||||||
|
if (hasNormalizerOn()) {
|
||||||
|
result = result && (getNormalizerOn()
|
||||||
|
== other.getNormalizerOn());
|
||||||
|
}
|
||||||
|
result = result &&
|
||||||
|
getUnknownFields().equals(other.getUnknownFields());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
private int memoizedHashCode = 0;
|
||||||
|
@java.lang.Override
|
||||||
|
public int hashCode() {
|
||||||
|
if (memoizedHashCode != 0) {
|
||||||
|
return memoizedHashCode;
|
||||||
|
}
|
||||||
|
int hash = 41;
|
||||||
|
hash = (19 * hash) + getDescriptorForType().hashCode();
|
||||||
|
if (hasNormalizerOn()) {
|
||||||
|
hash = (37 * hash) + NORMALIZER_ON_FIELD_NUMBER;
|
||||||
|
hash = (53 * hash) + hashBoolean(getNormalizerOn());
|
||||||
|
}
|
||||||
|
hash = (29 * hash) + getUnknownFields().hashCode();
|
||||||
|
memoizedHashCode = hash;
|
||||||
|
return hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(
|
||||||
|
com.google.protobuf.ByteString data)
|
||||||
|
throws com.google.protobuf.InvalidProtocolBufferException {
|
||||||
|
return PARSER.parseFrom(data);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(
|
||||||
|
com.google.protobuf.ByteString data,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws com.google.protobuf.InvalidProtocolBufferException {
|
||||||
|
return PARSER.parseFrom(data, extensionRegistry);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(byte[] data)
|
||||||
|
throws com.google.protobuf.InvalidProtocolBufferException {
|
||||||
|
return PARSER.parseFrom(data);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(
|
||||||
|
byte[] data,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws com.google.protobuf.InvalidProtocolBufferException {
|
||||||
|
return PARSER.parseFrom(data, extensionRegistry);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(java.io.InputStream input)
|
||||||
|
throws java.io.IOException {
|
||||||
|
return PARSER.parseFrom(input);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(
|
||||||
|
java.io.InputStream input,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws java.io.IOException {
|
||||||
|
return PARSER.parseFrom(input, extensionRegistry);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseDelimitedFrom(java.io.InputStream input)
|
||||||
|
throws java.io.IOException {
|
||||||
|
return PARSER.parseDelimitedFrom(input);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseDelimitedFrom(
|
||||||
|
java.io.InputStream input,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws java.io.IOException {
|
||||||
|
return PARSER.parseDelimitedFrom(input, extensionRegistry);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(
|
||||||
|
com.google.protobuf.CodedInputStream input)
|
||||||
|
throws java.io.IOException {
|
||||||
|
return PARSER.parseFrom(input);
|
||||||
|
}
|
||||||
|
public static org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parseFrom(
|
||||||
|
com.google.protobuf.CodedInputStream input,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws java.io.IOException {
|
||||||
|
return PARSER.parseFrom(input, extensionRegistry);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Builder newBuilder() { return Builder.create(); }
|
||||||
|
public Builder newBuilderForType() { return newBuilder(); }
|
||||||
|
public static Builder newBuilder(org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState prototype) {
|
||||||
|
return newBuilder().mergeFrom(prototype);
|
||||||
|
}
|
||||||
|
public Builder toBuilder() { return newBuilder(this); }
|
||||||
|
|
||||||
|
@java.lang.Override
|
||||||
|
protected Builder newBuilderForType(
|
||||||
|
com.google.protobuf.GeneratedMessage.BuilderParent parent) {
|
||||||
|
Builder builder = new Builder(parent);
|
||||||
|
return builder;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Protobuf type {@code RegionNormalizerState}
|
||||||
|
*/
|
||||||
|
public static final class Builder extends
|
||||||
|
com.google.protobuf.GeneratedMessage.Builder<Builder>
|
||||||
|
implements org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerStateOrBuilder {
|
||||||
|
public static final com.google.protobuf.Descriptors.Descriptor
|
||||||
|
getDescriptor() {
|
||||||
|
return org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.internal_static_RegionNormalizerState_descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable
|
||||||
|
internalGetFieldAccessorTable() {
|
||||||
|
return org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.internal_static_RegionNormalizerState_fieldAccessorTable
|
||||||
|
.ensureFieldAccessorsInitialized(
|
||||||
|
org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState.class, org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState.Builder.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Construct using org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState.newBuilder()
|
||||||
|
private Builder() {
|
||||||
|
maybeForceBuilderInitialization();
|
||||||
|
}
|
||||||
|
|
||||||
|
private Builder(
|
||||||
|
com.google.protobuf.GeneratedMessage.BuilderParent parent) {
|
||||||
|
super(parent);
|
||||||
|
maybeForceBuilderInitialization();
|
||||||
|
}
|
||||||
|
private void maybeForceBuilderInitialization() {
|
||||||
|
if (com.google.protobuf.GeneratedMessage.alwaysUseFieldBuilders) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private static Builder create() {
|
||||||
|
return new Builder();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder clear() {
|
||||||
|
super.clear();
|
||||||
|
normalizerOn_ = false;
|
||||||
|
bitField0_ = (bitField0_ & ~0x00000001);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder clone() {
|
||||||
|
return create().mergeFrom(buildPartial());
|
||||||
|
}
|
||||||
|
|
||||||
|
public com.google.protobuf.Descriptors.Descriptor
|
||||||
|
getDescriptorForType() {
|
||||||
|
return org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.internal_static_RegionNormalizerState_descriptor;
|
||||||
|
}
|
||||||
|
|
||||||
|
public org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState getDefaultInstanceForType() {
|
||||||
|
return org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState.getDefaultInstance();
|
||||||
|
}
|
||||||
|
|
||||||
|
public org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState build() {
|
||||||
|
org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState result = buildPartial();
|
||||||
|
if (!result.isInitialized()) {
|
||||||
|
throw newUninitializedMessageException(result);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState buildPartial() {
|
||||||
|
org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState result = new org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState(this);
|
||||||
|
int from_bitField0_ = bitField0_;
|
||||||
|
int to_bitField0_ = 0;
|
||||||
|
if (((from_bitField0_ & 0x00000001) == 0x00000001)) {
|
||||||
|
to_bitField0_ |= 0x00000001;
|
||||||
|
}
|
||||||
|
result.normalizerOn_ = normalizerOn_;
|
||||||
|
result.bitField0_ = to_bitField0_;
|
||||||
|
onBuilt();
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder mergeFrom(com.google.protobuf.Message other) {
|
||||||
|
if (other instanceof org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState) {
|
||||||
|
return mergeFrom((org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState)other);
|
||||||
|
} else {
|
||||||
|
super.mergeFrom(other);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder mergeFrom(org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState other) {
|
||||||
|
if (other == org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState.getDefaultInstance()) return this;
|
||||||
|
if (other.hasNormalizerOn()) {
|
||||||
|
setNormalizerOn(other.getNormalizerOn());
|
||||||
|
}
|
||||||
|
this.mergeUnknownFields(other.getUnknownFields());
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public final boolean isInitialized() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Builder mergeFrom(
|
||||||
|
com.google.protobuf.CodedInputStream input,
|
||||||
|
com.google.protobuf.ExtensionRegistryLite extensionRegistry)
|
||||||
|
throws java.io.IOException {
|
||||||
|
org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState parsedMessage = null;
|
||||||
|
try {
|
||||||
|
parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
|
||||||
|
} catch (com.google.protobuf.InvalidProtocolBufferException e) {
|
||||||
|
parsedMessage = (org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos.RegionNormalizerState) e.getUnfinishedMessage();
|
||||||
|
throw e;
|
||||||
|
} finally {
|
||||||
|
if (parsedMessage != null) {
|
||||||
|
mergeFrom(parsedMessage);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
private int bitField0_;
|
||||||
|
|
||||||
|
// optional bool normalizer_on = 1;
|
||||||
|
private boolean normalizerOn_ ;
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
public boolean hasNormalizerOn() {
|
||||||
|
return ((bitField0_ & 0x00000001) == 0x00000001);
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
public boolean getNormalizerOn() {
|
||||||
|
return normalizerOn_;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
public Builder setNormalizerOn(boolean value) {
|
||||||
|
bitField0_ |= 0x00000001;
|
||||||
|
normalizerOn_ = value;
|
||||||
|
onChanged();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* <code>optional bool normalizer_on = 1;</code>
|
||||||
|
*/
|
||||||
|
public Builder clearNormalizerOn() {
|
||||||
|
bitField0_ = (bitField0_ & ~0x00000001);
|
||||||
|
normalizerOn_ = false;
|
||||||
|
onChanged();
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// @@protoc_insertion_point(builder_scope:RegionNormalizerState)
|
||||||
|
}
|
||||||
|
|
||||||
|
static {
|
||||||
|
defaultInstance = new RegionNormalizerState(true);
|
||||||
|
defaultInstance.initFields();
|
||||||
|
}
|
||||||
|
|
||||||
|
// @@protoc_insertion_point(class_scope:RegionNormalizerState)
|
||||||
|
}
|
||||||
|
|
||||||
|
private static com.google.protobuf.Descriptors.Descriptor
|
||||||
|
internal_static_RegionNormalizerState_descriptor;
|
||||||
|
private static
|
||||||
|
com.google.protobuf.GeneratedMessage.FieldAccessorTable
|
||||||
|
internal_static_RegionNormalizerState_fieldAccessorTable;
|
||||||
|
|
||||||
|
public static com.google.protobuf.Descriptors.FileDescriptor
|
||||||
|
getDescriptor() {
|
||||||
|
return descriptor;
|
||||||
|
}
|
||||||
|
private static com.google.protobuf.Descriptors.FileDescriptor
|
||||||
|
descriptor;
|
||||||
|
static {
|
||||||
|
java.lang.String[] descriptorData = {
|
||||||
|
"\n\026RegionNormalizer.proto\".\n\025RegionNormal" +
|
||||||
|
"izerState\022\025\n\rnormalizer_on\030\001 \001(\010BI\n*org." +
|
||||||
|
"apache.hadoop.hbase.protobuf.generatedB\026" +
|
||||||
|
"RegionNormalizerProtosH\001\240\001\001"
|
||||||
|
};
|
||||||
|
com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner =
|
||||||
|
new com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner() {
|
||||||
|
public com.google.protobuf.ExtensionRegistry assignDescriptors(
|
||||||
|
com.google.protobuf.Descriptors.FileDescriptor root) {
|
||||||
|
descriptor = root;
|
||||||
|
internal_static_RegionNormalizerState_descriptor =
|
||||||
|
getDescriptor().getMessageTypes().get(0);
|
||||||
|
internal_static_RegionNormalizerState_fieldAccessorTable = new
|
||||||
|
com.google.protobuf.GeneratedMessage.FieldAccessorTable(
|
||||||
|
internal_static_RegionNormalizerState_descriptor,
|
||||||
|
new java.lang.String[] { "NormalizerOn", });
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
com.google.protobuf.Descriptors.FileDescriptor
|
||||||
|
.internalBuildGeneratedFileFrom(descriptorData,
|
||||||
|
new com.google.protobuf.Descriptors.FileDescriptor[] {
|
||||||
|
}, assigner);
|
||||||
|
}
|
||||||
|
|
||||||
|
// @@protoc_insertion_point(outer_class_scope)
|
||||||
|
}
|
|
@ -271,6 +271,28 @@ message IsBalancerEnabledResponse {
|
||||||
required bool enabled = 1;
|
required bool enabled = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
message NormalizeRequest {
|
||||||
|
}
|
||||||
|
|
||||||
|
message NormalizeResponse {
|
||||||
|
required bool normalizer_ran = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message SetNormalizerRunningRequest {
|
||||||
|
required bool on = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message SetNormalizerRunningResponse {
|
||||||
|
optional bool prev_normalizer_value = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
message IsNormalizerEnabledRequest {
|
||||||
|
}
|
||||||
|
|
||||||
|
message IsNormalizerEnabledResponse {
|
||||||
|
required bool enabled = 1;
|
||||||
|
}
|
||||||
|
|
||||||
message RunCatalogScanRequest {
|
message RunCatalogScanRequest {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -594,6 +616,24 @@ service MasterService {
|
||||||
rpc IsBalancerEnabled(IsBalancerEnabledRequest)
|
rpc IsBalancerEnabled(IsBalancerEnabledRequest)
|
||||||
returns(IsBalancerEnabledResponse);
|
returns(IsBalancerEnabledResponse);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Run region normalizer. Can NOT run for various reasons. Check logs.
|
||||||
|
*/
|
||||||
|
rpc Normalize(NormalizeRequest)
|
||||||
|
returns(NormalizeResponse);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn region normalizer on or off.
|
||||||
|
*/
|
||||||
|
rpc SetNormalizerRunning(SetNormalizerRunningRequest)
|
||||||
|
returns(SetNormalizerRunningResponse);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Query whether region normalizer is enabled.
|
||||||
|
*/
|
||||||
|
rpc IsNormalizerEnabled(IsNormalizerEnabledRequest)
|
||||||
|
returns(IsNormalizerEnabledResponse);
|
||||||
|
|
||||||
/** Get a run of the catalog janitor */
|
/** Get a run of the catalog janitor */
|
||||||
rpc RunCatalogScan(RunCatalogScanRequest)
|
rpc RunCatalogScan(RunCatalogScanRequest)
|
||||||
returns(RunCatalogScanResponse);
|
returns(RunCatalogScanResponse);
|
||||||
|
|
|
@ -0,0 +1,28 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
// This file contains protocol buffers to represent the state of the load balancer.
|
||||||
|
|
||||||
|
option java_package = "org.apache.hadoop.hbase.protobuf.generated";
|
||||||
|
option java_outer_classname = "RegionNormalizerProtos";
|
||||||
|
option java_generate_equals_and_hash = true;
|
||||||
|
option optimize_for = SPEED;
|
||||||
|
|
||||||
|
message RegionNormalizerState {
|
||||||
|
optional bool normalizer_on = 1;
|
||||||
|
}
|
|
@ -147,6 +147,7 @@ import org.apache.hadoop.hbase.zookeeper.DrainingServerTracker;
|
||||||
import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;
|
import org.apache.hadoop.hbase.zookeeper.LoadBalancerTracker;
|
||||||
import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;
|
import org.apache.hadoop.hbase.zookeeper.MasterAddressTracker;
|
||||||
import org.apache.hadoop.hbase.zookeeper.MetaTableLocator;
|
import org.apache.hadoop.hbase.zookeeper.MetaTableLocator;
|
||||||
|
import org.apache.hadoop.hbase.zookeeper.RegionNormalizerTracker;
|
||||||
import org.apache.hadoop.hbase.zookeeper.RegionServerTracker;
|
import org.apache.hadoop.hbase.zookeeper.RegionServerTracker;
|
||||||
import org.apache.hadoop.hbase.zookeeper.ZKClusterId;
|
import org.apache.hadoop.hbase.zookeeper.ZKClusterId;
|
||||||
import org.apache.hadoop.hbase.zookeeper.ZKUtil;
|
import org.apache.hadoop.hbase.zookeeper.ZKUtil;
|
||||||
|
@ -246,6 +247,9 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
// Tracker for load balancer state
|
// Tracker for load balancer state
|
||||||
LoadBalancerTracker loadBalancerTracker;
|
LoadBalancerTracker loadBalancerTracker;
|
||||||
|
|
||||||
|
// Tracker for region normalizer state
|
||||||
|
private RegionNormalizerTracker regionNormalizerTracker;
|
||||||
|
|
||||||
/** Namespace stuff */
|
/** Namespace stuff */
|
||||||
private TableNamespaceManager tableNamespaceManager;
|
private TableNamespaceManager tableNamespaceManager;
|
||||||
|
|
||||||
|
@ -280,8 +284,7 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
private volatile boolean serverCrashProcessingEnabled = false;
|
private volatile boolean serverCrashProcessingEnabled = false;
|
||||||
|
|
||||||
LoadBalancer balancer;
|
LoadBalancer balancer;
|
||||||
RegionNormalizer normalizer;
|
private RegionNormalizer normalizer;
|
||||||
private boolean normalizerEnabled = false;
|
|
||||||
private BalancerChore balancerChore;
|
private BalancerChore balancerChore;
|
||||||
private RegionNormalizerChore normalizerChore;
|
private RegionNormalizerChore normalizerChore;
|
||||||
private ClusterStatusChore clusterStatusChore;
|
private ClusterStatusChore clusterStatusChore;
|
||||||
|
@ -556,9 +559,10 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
this.balancer = LoadBalancerFactory.getLoadBalancer(conf);
|
this.balancer = LoadBalancerFactory.getLoadBalancer(conf);
|
||||||
this.normalizer = RegionNormalizerFactory.getRegionNormalizer(conf);
|
this.normalizer = RegionNormalizerFactory.getRegionNormalizer(conf);
|
||||||
this.normalizer.setMasterServices(this);
|
this.normalizer.setMasterServices(this);
|
||||||
this.normalizerEnabled = conf.getBoolean(HConstants.HBASE_NORMALIZER_ENABLED, false);
|
|
||||||
this.loadBalancerTracker = new LoadBalancerTracker(zooKeeper, this);
|
this.loadBalancerTracker = new LoadBalancerTracker(zooKeeper, this);
|
||||||
this.loadBalancerTracker.start();
|
this.loadBalancerTracker.start();
|
||||||
|
this.regionNormalizerTracker = new RegionNormalizerTracker(zooKeeper, this);
|
||||||
|
this.regionNormalizerTracker.start();
|
||||||
this.assignmentManager = new AssignmentManager(this, serverManager,
|
this.assignmentManager = new AssignmentManager(this, serverManager,
|
||||||
this.balancer, this.service, this.metricsMaster,
|
this.balancer, this.service, this.metricsMaster,
|
||||||
this.tableLockManager);
|
this.tableLockManager);
|
||||||
|
@ -1329,7 +1333,7 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!this.normalizerEnabled) {
|
if (!this.regionNormalizerTracker.isNormalizerOn()) {
|
||||||
LOG.debug("Region normalization is disabled, don't run region normalizer.");
|
LOG.debug("Region normalization is disabled, don't run region normalizer.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -2649,6 +2653,17 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
return loadBalancerTracker.isBalancerOn();
|
return loadBalancerTracker.isBalancerOn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queries the state of the {@link RegionNormalizerTracker}. If it's not initialized,
|
||||||
|
* false is returned.
|
||||||
|
*/
|
||||||
|
public boolean isNormalizerOn() {
|
||||||
|
if (null == regionNormalizerTracker) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return regionNormalizerTracker.isNormalizerOn();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fetch the configured {@link LoadBalancer} class name. If none is set, a default is returned.
|
* Fetch the configured {@link LoadBalancer} class name. If none is set, a default is returned.
|
||||||
*
|
*
|
||||||
|
@ -2658,4 +2673,11 @@ public class HMaster extends HRegionServer implements MasterServices, Server {
|
||||||
return conf.get(HConstants.HBASE_MASTER_LOADBALANCER_CLASS, LoadBalancerFactory
|
return conf.get(HConstants.HBASE_MASTER_LOADBALANCER_CLASS, LoadBalancerFactory
|
||||||
.getDefaultLoadBalancerClass().getName());
|
.getDefaultLoadBalancerClass().getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return RegionNormalizerTracker instance
|
||||||
|
*/
|
||||||
|
public RegionNormalizerTracker getRegionNormalizerTracker() {
|
||||||
|
return regionNormalizerTracker;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,7 @@ import java.util.Set;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
import org.apache.hadoop.hbase.CoordinatedStateException;
|
||||||
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.hbase.HColumnDescriptor;
|
import org.apache.hadoop.hbase.HColumnDescriptor;
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
|
@ -108,6 +109,8 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorE
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorEnabledResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsCatalogJanitorEnabledResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsMasterRunningResponse;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsNormalizerEnabledRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsNormalizerEnabledResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsProcedureDoneResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsRestoreSnapshotDoneRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.IsRestoreSnapshotDoneRequest;
|
||||||
|
@ -134,6 +137,8 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableReques
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ModifyTableResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.MoveRegionResponse;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.NormalizeRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.NormalizeResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.OfflineRegionResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RestoreSnapshotRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.RestoreSnapshotRequest;
|
||||||
|
@ -145,6 +150,8 @@ import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilit
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilitiesResponse.Capability;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SecurityCapabilitiesResponse.Capability;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetBalancerRunningResponse;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetNormalizerRunningRequest;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetNormalizerRunningResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaRequest;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaResponse;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.SetQuotaResponse;
|
||||||
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ShutdownRequest;
|
import org.apache.hadoop.hbase.protobuf.generated.MasterProtos.ShutdownRequest;
|
||||||
|
@ -272,6 +279,25 @@ public class MasterRpcServices extends RSRpcServices
|
||||||
return switchBalancer(b, BalanceSwitchMode.SYNC);
|
return switchBalancer(b, BalanceSwitchMode.SYNC);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets normalizer on/off flag in ZK.
|
||||||
|
*/
|
||||||
|
public boolean normalizerSwitch(boolean on) {
|
||||||
|
boolean oldValue = master.getRegionNormalizerTracker().isNormalizerOn();
|
||||||
|
boolean newValue = on;
|
||||||
|
try {
|
||||||
|
try {
|
||||||
|
master.getRegionNormalizerTracker().setNormalizerOn(newValue);
|
||||||
|
} catch (KeeperException ke) {
|
||||||
|
throw new IOException(ke);
|
||||||
|
}
|
||||||
|
LOG.info(master.getClientIdAuditPrefix() + " set normalizerSwitch=" + newValue);
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
LOG.warn("Error flipping normalizer switch", ioe);
|
||||||
|
}
|
||||||
|
return oldValue;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return list of blocking services and their security info classes that this server supports
|
* @return list of blocking services and their security info classes that this server supports
|
||||||
*/
|
*/
|
||||||
|
@ -1429,6 +1455,36 @@ public class MasterRpcServices extends RSRpcServices
|
||||||
return response.build();
|
return response.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public NormalizeResponse normalize(RpcController controller,
|
||||||
|
NormalizeRequest request) throws ServiceException {
|
||||||
|
try {
|
||||||
|
return NormalizeResponse.newBuilder().setNormalizerRan(master.normalizeRegions()).build();
|
||||||
|
} catch (IOException | CoordinatedStateException ex) {
|
||||||
|
throw new ServiceException(ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SetNormalizerRunningResponse setNormalizerRunning(RpcController controller,
|
||||||
|
SetNormalizerRunningRequest request) throws ServiceException {
|
||||||
|
try {
|
||||||
|
master.checkInitialized();
|
||||||
|
boolean prevValue = normalizerSwitch(request.getOn());
|
||||||
|
return SetNormalizerRunningResponse.newBuilder().setPrevNormalizerValue(prevValue).build();
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
throw new ServiceException(ioe);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public IsNormalizerEnabledResponse isNormalizerEnabled(RpcController controller,
|
||||||
|
IsNormalizerEnabledRequest request) throws ServiceException {
|
||||||
|
IsNormalizerEnabledResponse.Builder response = IsNormalizerEnabledResponse.newBuilder();
|
||||||
|
response.setEnabled(master.isNormalizerOn());
|
||||||
|
return response.build();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public SetQuotaResponse setQuota(RpcController c, SetQuotaRequest req) throws ServiceException {
|
public SetQuotaResponse setQuota(RpcController c, SetQuotaRequest req) throws ServiceException {
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -0,0 +1,94 @@
|
||||||
|
/**
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.hadoop.hbase.zookeeper;
|
||||||
|
|
||||||
|
import org.apache.commons.logging.Log;
|
||||||
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
import org.apache.hadoop.hbase.Abortable;
|
||||||
|
import org.apache.hadoop.hbase.exceptions.DeserializationException;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.ProtobufUtil;
|
||||||
|
import org.apache.hadoop.hbase.protobuf.generated.RegionNormalizerProtos;
|
||||||
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
import org.apache.zookeeper.KeeperException;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tracks region normalizer state up in ZK
|
||||||
|
*/
|
||||||
|
public class RegionNormalizerTracker extends ZooKeeperNodeTracker {
|
||||||
|
private static final Log LOG = LogFactory.getLog(RegionNormalizerTracker.class);
|
||||||
|
|
||||||
|
public RegionNormalizerTracker(ZooKeeperWatcher watcher,
|
||||||
|
Abortable abortable) {
|
||||||
|
super(watcher, watcher.getRegionNormalizerZNode(), abortable);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return true if region normalizer is on, false otherwise
|
||||||
|
*/
|
||||||
|
public boolean isNormalizerOn() {
|
||||||
|
byte [] upData = super.getData(false);
|
||||||
|
try {
|
||||||
|
// if data in ZK is null, use default of on.
|
||||||
|
return upData == null || parseFrom(upData).getNormalizerOn();
|
||||||
|
} catch (DeserializationException dex) {
|
||||||
|
LOG.error("ZK state for RegionNormalizer could not be parsed "
|
||||||
|
+ Bytes.toStringBinary(upData));
|
||||||
|
// return false to be safe.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set region normalizer on/off
|
||||||
|
* @param normalizerOn whether normalizer should be on or off
|
||||||
|
* @throws KeeperException
|
||||||
|
*/
|
||||||
|
public void setNormalizerOn(boolean normalizerOn) throws KeeperException {
|
||||||
|
byte [] upData = toByteArray(normalizerOn);
|
||||||
|
try {
|
||||||
|
ZKUtil.setData(watcher, watcher.getRegionNormalizerZNode(), upData);
|
||||||
|
} catch(KeeperException.NoNodeException nne) {
|
||||||
|
ZKUtil.createAndWatch(watcher, watcher.getRegionNormalizerZNode(), upData);
|
||||||
|
}
|
||||||
|
super.nodeDataChanged(watcher.getRegionNormalizerZNode());
|
||||||
|
}
|
||||||
|
|
||||||
|
private byte [] toByteArray(boolean isNormalizerOn) {
|
||||||
|
RegionNormalizerProtos.RegionNormalizerState.Builder builder =
|
||||||
|
RegionNormalizerProtos.RegionNormalizerState.newBuilder();
|
||||||
|
builder.setNormalizerOn(isNormalizerOn);
|
||||||
|
return ProtobufUtil.prependPBMagic(builder.build().toByteArray());
|
||||||
|
}
|
||||||
|
|
||||||
|
private RegionNormalizerProtos.RegionNormalizerState parseFrom(byte [] pbBytes)
|
||||||
|
throws DeserializationException {
|
||||||
|
ProtobufUtil.expectPBMagicPrefix(pbBytes);
|
||||||
|
RegionNormalizerProtos.RegionNormalizerState.Builder builder =
|
||||||
|
RegionNormalizerProtos.RegionNormalizerState.newBuilder();
|
||||||
|
try {
|
||||||
|
int magicLen = ProtobufUtil.lengthOfPBMagic();
|
||||||
|
ProtobufUtil.mergeFrom(builder, pbBytes, magicLen, pbBytes.length - magicLen);
|
||||||
|
} catch (IOException e) {
|
||||||
|
throw new DeserializationException(e);
|
||||||
|
}
|
||||||
|
return builder.build();
|
||||||
|
}
|
||||||
|
}
|
|
@ -768,4 +768,26 @@ public class TestAdmin2 {
|
||||||
ProcedureInfo[] procList = admin.listProcedures();
|
ProcedureInfo[] procList = admin.listProcedures();
|
||||||
assertTrue(procList.length >= 0);
|
assertTrue(procList.length >= 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test(timeout = 30000)
|
||||||
|
public void testRegionNormalizer() throws Exception {
|
||||||
|
boolean initialState = admin.isNormalizerEnabled();
|
||||||
|
|
||||||
|
// flip state
|
||||||
|
boolean prevState = admin.setNormalizerRunning(!initialState);
|
||||||
|
|
||||||
|
// The previous state should be the original state we observed
|
||||||
|
assertEquals(initialState, prevState);
|
||||||
|
|
||||||
|
// Current state should be opposite of the original
|
||||||
|
assertEquals(!initialState, admin.isNormalizerEnabled());
|
||||||
|
|
||||||
|
// Reset it back to what it was
|
||||||
|
prevState = admin.setNormalizerRunning(initialState);
|
||||||
|
|
||||||
|
// The previous state should be the opposite of the initial state
|
||||||
|
assertEquals(!initialState, prevState);
|
||||||
|
// Current state should be the original state again
|
||||||
|
assertEquals(initialState, admin.isNormalizerEnabled());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -121,6 +121,27 @@ module Hbase
|
||||||
@admin.isBalancerEnabled()
|
@admin.isBalancerEnabled()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------------------------------
|
||||||
|
# Requests region normalization for all configured tables in the cluster
|
||||||
|
# Returns true if normalizer ran successfully
|
||||||
|
def normalize()
|
||||||
|
@admin.normalize()
|
||||||
|
end
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------------------------------
|
||||||
|
# Enable/disable region normalizer
|
||||||
|
# Returns previous normalizer switch setting.
|
||||||
|
def normalizer_switch(enableDisable)
|
||||||
|
@admin.setNormalizerRunning(java.lang.Boolean::valueOf(enableDisable))
|
||||||
|
end
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------------------------------
|
||||||
|
# Query the current state of region normalizer.
|
||||||
|
# Returns the state of region normalizer (true is enabled).
|
||||||
|
def normalizer_enabled?()
|
||||||
|
@admin.isNormalizerEnabled()
|
||||||
|
end
|
||||||
|
|
||||||
#----------------------------------------------------------------------------------------------
|
#----------------------------------------------------------------------------------------------
|
||||||
# Request a scan of the catalog table (for garbage collection)
|
# Request a scan of the catalog table (for garbage collection)
|
||||||
# Returns an int signifying the number of entries cleaned
|
# Returns an int signifying the number of entries cleaned
|
||||||
|
@ -559,6 +580,8 @@ module Hbase
|
||||||
htd.setMaxFileSize(JLong.valueOf(arg.delete(MAX_FILESIZE))) if arg[MAX_FILESIZE]
|
htd.setMaxFileSize(JLong.valueOf(arg.delete(MAX_FILESIZE))) if arg[MAX_FILESIZE]
|
||||||
htd.setReadOnly(JBoolean.valueOf(arg.delete(READONLY))) if arg[READONLY]
|
htd.setReadOnly(JBoolean.valueOf(arg.delete(READONLY))) if arg[READONLY]
|
||||||
htd.setCompactionEnabled(JBoolean.valueOf(arg[COMPACTION_ENABLED])) if arg[COMPACTION_ENABLED]
|
htd.setCompactionEnabled(JBoolean.valueOf(arg[COMPACTION_ENABLED])) if arg[COMPACTION_ENABLED]
|
||||||
|
htd.setNormalizationEnabled(
|
||||||
|
JBoolean.valueOf(arg[NORMALIZATION_ENABLED])) if arg[NORMALIZATION_ENABLED]
|
||||||
htd.setMemStoreFlushSize(JLong.valueOf(arg.delete(MEMSTORE_FLUSHSIZE))) if arg[MEMSTORE_FLUSHSIZE]
|
htd.setMemStoreFlushSize(JLong.valueOf(arg.delete(MEMSTORE_FLUSHSIZE))) if arg[MEMSTORE_FLUSHSIZE]
|
||||||
# DEFERRED_LOG_FLUSH is deprecated and was replaced by DURABILITY. To keep backward compatible, it still exists.
|
# DEFERRED_LOG_FLUSH is deprecated and was replaced by DURABILITY. To keep backward compatible, it still exists.
|
||||||
# However, it has to be set before DURABILITY so that DURABILITY could overwrite if both args are set
|
# However, it has to be set before DURABILITY so that DURABILITY could overwrite if both args are set
|
||||||
|
|
|
@ -314,6 +314,9 @@ Shell.load_command_group(
|
||||||
balancer
|
balancer
|
||||||
balance_switch
|
balance_switch
|
||||||
balancer_enabled
|
balancer_enabled
|
||||||
|
normalize
|
||||||
|
normalizer_switch
|
||||||
|
normalizer_enabled
|
||||||
close_region
|
close_region
|
||||||
compact
|
compact
|
||||||
flush
|
flush
|
||||||
|
|
|
@ -0,0 +1,45 @@
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
# or more contributor license agreements. See the NOTICE file
|
||||||
|
# distributed with this work for additional information
|
||||||
|
# regarding copyright ownership. The ASF licenses this file
|
||||||
|
# to you under the Apache License, Version 2.0 (the
|
||||||
|
# "License"); you may not use this file except in compliance
|
||||||
|
# with the License. You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
module Shell
|
||||||
|
module Commands
|
||||||
|
class Normalize < Command
|
||||||
|
def help
|
||||||
|
return <<-EOF
|
||||||
|
Trigger region normalizer for all tables which have NORMALIZATION_ENABLED flag set. Returns true
|
||||||
|
if normalizer ran successfully, false otherwise. Note that this command has no effect
|
||||||
|
if region normalizer is disabled (make sure it's turned on using 'normalizer_switch' command).
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
|
||||||
|
hbase> normalize
|
||||||
|
EOF
|
||||||
|
end
|
||||||
|
|
||||||
|
def command()
|
||||||
|
format_simple_command do
|
||||||
|
formatter.row([
|
||||||
|
admin.normalize()? "true": "false"
|
||||||
|
])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
|
@ -0,0 +1,41 @@
|
||||||
|
#!/usr/bin/env hbase-jruby
|
||||||
|
#
|
||||||
|
# Licensed to the Apache Software Foundation (ASF) under one or more
|
||||||
|
# contributor license agreements. See the NOTICE file distributed with this
|
||||||
|
# work for additional information regarding copyright ownership. The ASF
|
||||||
|
# licenses this file to you under the Apache License, Version 2.0 (the
|
||||||
|
# "License"); you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
# Prints current region normalizer status
|
||||||
|
|
||||||
|
module Shell
|
||||||
|
module Commands
|
||||||
|
class NormalizerEnabled < Command
|
||||||
|
def help
|
||||||
|
return <<-EOF
|
||||||
|
Query the state of region normalizer.
|
||||||
|
Examples:
|
||||||
|
|
||||||
|
hbase> normalizer_enabled
|
||||||
|
EOF
|
||||||
|
end
|
||||||
|
|
||||||
|
def command()
|
||||||
|
format_simple_command do
|
||||||
|
formatter.row([
|
||||||
|
admin.normalizer_enabled?.to_s
|
||||||
|
])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,43 @@
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
# or more contributor license agreements. See the NOTICE file
|
||||||
|
# distributed with this work for additional information
|
||||||
|
# regarding copyright ownership. The ASF licenses this file
|
||||||
|
# to you under the Apache License, Version 2.0 (the
|
||||||
|
# "License"); you may not use this file except in compliance
|
||||||
|
# with the License. You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
module Shell
|
||||||
|
module Commands
|
||||||
|
class NormalizerSwitch < Command
|
||||||
|
def help
|
||||||
|
return <<-EOF
|
||||||
|
Enable/Disable region normalizer. Returns previous normalizer state.
|
||||||
|
When normalizer is enabled, it handles all tables with 'NORMALIZATION_ENABLED' => true.
|
||||||
|
Examples:
|
||||||
|
|
||||||
|
hbase> normalizer_switch true
|
||||||
|
hbase> normalizer_switch false
|
||||||
|
EOF
|
||||||
|
end
|
||||||
|
|
||||||
|
def command(enableDisable)
|
||||||
|
format_simple_command do
|
||||||
|
formatter.row([
|
||||||
|
admin.normalizer_switch(enableDisable)? "true" : "false"
|
||||||
|
])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue