All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.hadoop.hbase.ClusterStatus Maven / Gradle / Ivy

/**
 *
 * 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;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

import org.apache.hadoop.hbase.util.ByteStringer;
import org.apache.hadoop.hbase.classification.InterfaceAudience;
import org.apache.hadoop.hbase.classification.InterfaceStability;
import org.apache.hadoop.hbase.master.RegionState;
import org.apache.hadoop.hbase.protobuf.ProtobufUtil;
import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos;
import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos.LiveServerInfo;
import org.apache.hadoop.hbase.protobuf.generated.ClusterStatusProtos.RegionInTransition;
import org.apache.hadoop.hbase.protobuf.generated.FSProtos.HBaseVersionFileContent;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.RegionSpecifier;
import org.apache.hadoop.hbase.protobuf.generated.HBaseProtos.RegionSpecifier.RegionSpecifierType;
import org.apache.hadoop.hbase.util.Bytes;
import org.apache.hadoop.io.VersionedWritable;


/**
 * Status information on the HBase cluster.
 * 

* ClusterStatus provides clients with information such as: *

    *
  • The count and names of region servers in the cluster.
  • *
  • The count and names of dead region servers in the cluster.
  • *
  • The name of the active master for the cluster.
  • *
  • The name(s) of the backup master(s) for the cluster, if they exist.
  • *
  • The average cluster load.
  • *
  • The number of regions deployed on the cluster.
  • *
  • The number of requests since last report.
  • *
  • Detailed region server loading and resource usage information, * per server and per region.
  • *
  • Regions in transition at master
  • *
  • The unique cluster ID
  • *
*/ @InterfaceAudience.Public @InterfaceStability.Evolving public class ClusterStatus extends VersionedWritable { /** * Version for object serialization. Incremented for changes in serialized * representation. *
*
0
Initial version
*
1
Added cluster ID
*
2
Added Map of ServerName to ServerLoad
*
3
Added master and backupMasters
*
*/ private static final byte VERSION = 2; private String hbaseVersion; private Map liveServers; private Collection deadServers; private ServerName master; private Collection backupMasters; private Map intransition; private String clusterId; private String[] masterCoprocessors; private Boolean balancerOn; /** * Constructor, for Writable * @deprecated As of release 0.96 * (HBASE-6038). * This will be removed in HBase 2.0.0. * Used by Writables and Writables are going away. */ @Deprecated public ClusterStatus() { super(); } public ClusterStatus(final String hbaseVersion, final String clusterid, final Map servers, final Collection deadServers, final ServerName master, final Collection backupMasters, final Map rit, final String[] masterCoprocessors, final Boolean balancerOn) { this.hbaseVersion = hbaseVersion; this.liveServers = servers; this.deadServers = deadServers; this.master = master; this.backupMasters = backupMasters; this.intransition = rit; this.clusterId = clusterid; this.masterCoprocessors = masterCoprocessors; this.balancerOn = balancerOn; } /** * @return the names of region servers on the dead list */ public Collection getDeadServerNames() { if (deadServers == null) { return Collections.emptyList(); } return Collections.unmodifiableCollection(deadServers); } /** * @return the number of region servers in the cluster */ public int getServersSize() { return liveServers != null ? liveServers.size() : 0; } /** * @return the number of dead region servers in the cluster */ public int getDeadServers() { return deadServers != null ? deadServers.size() : 0; } /** * @return the average cluster load */ public double getAverageLoad() { int load = getRegionsCount(); return (double)load / (double)getServersSize(); } /** * @return the number of regions deployed on the cluster */ public int getRegionsCount() { int count = 0; if (liveServers != null && !liveServers.isEmpty()) { for (Map.Entry e: this.liveServers.entrySet()) { count += e.getValue().getNumberOfRegions(); } } return count; } /** * @return the number of requests since last report */ public int getRequestsCount() { int count = 0; if (liveServers != null && !liveServers.isEmpty()) { for (Map.Entry e: this.liveServers.entrySet()) { count += e.getValue().getNumberOfRequests(); } } return count; } /** * @return the HBase version string as reported by the HMaster */ public String getHBaseVersion() { return hbaseVersion; } /** * @see java.lang.Object#equals(java.lang.Object) */ public boolean equals(Object o) { if (this == o) { return true; } if (!(o instanceof ClusterStatus)) { return false; } return (getVersion() == ((ClusterStatus)o).getVersion()) && getHBaseVersion().equals(((ClusterStatus)o).getHBaseVersion()) && this.liveServers.equals(((ClusterStatus)o).liveServers) && this.deadServers.containsAll(((ClusterStatus)o).deadServers) && Arrays.equals(this.masterCoprocessors, ((ClusterStatus)o).masterCoprocessors) && this.master.equals(((ClusterStatus)o).master) && this.backupMasters.containsAll(((ClusterStatus)o).backupMasters); } /** * @see java.lang.Object#hashCode() */ public int hashCode() { return VERSION + hbaseVersion.hashCode() + this.liveServers.hashCode() + this.deadServers.hashCode() + this.master.hashCode() + this.backupMasters.hashCode(); } /** @return the object version number */ public byte getVersion() { return VERSION; } // // Getters // /** * Returns detailed region server information: A list of * {@link ServerName}. * @return region server information * @deprecated As of release 0.92 * (HBASE-1502). * This will be removed in HBase 2.0.0. * Use {@link #getServers()}. */ @Deprecated public Collection getServerInfo() { return getServers(); } public Collection getServers() { if (liveServers == null) { return Collections.emptyList(); } return Collections.unmodifiableCollection(this.liveServers.keySet()); } /** * Returns detailed information about the current master {@link ServerName}. * @return current master information if it exists */ public ServerName getMaster() { return this.master; } /** * @return the number of backup masters in the cluster */ public int getBackupMastersSize() { return backupMasters != null ? backupMasters.size() : 0; } /** * @return the names of backup masters */ public Collection getBackupMasters() { if (backupMasters == null) { return Collections.emptyList(); } return Collections.unmodifiableCollection(this.backupMasters); } /** * @param sn * @return Server's load or null if not found. */ public ServerLoad getLoad(final ServerName sn) { return liveServers != null ? liveServers.get(sn) : null; } @InterfaceAudience.Private public Map getRegionsInTransition() { return this.intransition; } public String getClusterId() { return clusterId; } public String[] getMasterCoprocessors() { return masterCoprocessors; } public long getLastMajorCompactionTsForTable(TableName table) { long result = Long.MAX_VALUE; for (ServerName server : getServers()) { ServerLoad load = getLoad(server); for (RegionLoad rl : load.getRegionsLoad().values()) { if (table.equals(HRegionInfo.getTable(rl.getName()))) { result = Math.min(result, rl.getLastMajorCompactionTs()); } } } return result == Long.MAX_VALUE ? 0 : result; } public long getLastMajorCompactionTsForRegion(final byte[] region) { for (ServerName server : getServers()) { ServerLoad load = getLoad(server); RegionLoad rl = load.getRegionsLoad().get(region); if (rl != null) { return rl.getLastMajorCompactionTs(); } } return 0; } public boolean isBalancerOn() { return balancerOn != null && balancerOn; } public Boolean getBalancerOn() { return balancerOn; } public String toString() { StringBuilder sb = new StringBuilder(1024); sb.append("Master: " + master); int backupMastersSize = getBackupMastersSize(); sb.append("\nNumber of backup masters: " + backupMastersSize); if (backupMastersSize > 0) { for (ServerName serverName: backupMasters) { sb.append("\n " + serverName); } } int serversSize = getServersSize(); sb.append("\nNumber of live region servers: " + serversSize); if (serversSize > 0) { for (ServerName serverName: liveServers.keySet()) { sb.append("\n " + serverName.getServerName()); } } int deadServerSize = getDeadServers(); sb.append("\nNumber of dead region servers: " + deadServerSize); if (deadServerSize > 0) { for (ServerName serverName: deadServers) { sb.append("\n " + serverName); } } sb.append("\nAverage load: " + getAverageLoad()); sb.append("\nNumber of requests: " + getRequestsCount()); sb.append("\nNumber of regions: " + getRegionsCount()); int ritSize = (intransition != null) ? intransition.size() : 0; sb.append("\nNumber of regions in transition: " + ritSize); if (ritSize > 0) { for (RegionState state: intransition.values()) { sb.append("\n " + state.toDescriptiveString()); } } return sb.toString(); } /** * Convert a ClusterStatus to a protobuf ClusterStatus * * @return the protobuf ClusterStatus */ public ClusterStatusProtos.ClusterStatus convert() { ClusterStatusProtos.ClusterStatus.Builder builder = ClusterStatusProtos.ClusterStatus.newBuilder(); builder.setHbaseVersion(HBaseVersionFileContent.newBuilder().setVersion(getHBaseVersion())); if (liveServers != null){ for (Map.Entry entry : liveServers.entrySet()) { LiveServerInfo.Builder lsi = LiveServerInfo.newBuilder().setServer(ProtobufUtil.toServerName(entry.getKey())); lsi.setServerLoad(entry.getValue().obtainServerLoadPB()); builder.addLiveServers(lsi.build()); } } if (deadServers != null){ for (ServerName deadServer : deadServers) { builder.addDeadServers(ProtobufUtil.toServerName(deadServer)); } } if (intransition != null) { for (Map.Entry rit : getRegionsInTransition().entrySet()) { ClusterStatusProtos.RegionState rs = rit.getValue().convert(); RegionSpecifier.Builder spec = RegionSpecifier.newBuilder().setType(RegionSpecifierType.REGION_NAME); spec.setValue(ByteStringer.wrap(Bytes.toBytes(rit.getKey()))); RegionInTransition pbRIT = RegionInTransition.newBuilder().setSpec(spec.build()).setRegionState(rs).build(); builder.addRegionsInTransition(pbRIT); } } if (clusterId != null) { builder.setClusterId(new ClusterId(clusterId).convert()); } if (masterCoprocessors != null) { for (String coprocessor : masterCoprocessors) { builder.addMasterCoprocessors(HBaseProtos.Coprocessor.newBuilder().setName(coprocessor)); } } if (master != null){ builder.setMaster(ProtobufUtil.toServerName(getMaster())); } if (backupMasters != null) { for (ServerName backup : backupMasters) { builder.addBackupMasters(ProtobufUtil.toServerName(backup)); } } if (balancerOn != null){ builder.setBalancerOn(balancerOn); } return builder.build(); } /** * Convert a protobuf ClusterStatus to a ClusterStatus * * @param proto the protobuf ClusterStatus * @return the converted ClusterStatus */ public static ClusterStatus convert(ClusterStatusProtos.ClusterStatus proto) { Map servers = null; if (proto.getLiveServersList() != null) { servers = new HashMap(proto.getLiveServersList().size()); for (LiveServerInfo lsi : proto.getLiveServersList()) { servers.put(ProtobufUtil.toServerName( lsi.getServer()), new ServerLoad(lsi.getServerLoad())); } } Collection deadServers = null; if (proto.getDeadServersList() != null) { deadServers = new ArrayList(proto.getDeadServersList().size()); for (HBaseProtos.ServerName sn : proto.getDeadServersList()) { deadServers.add(ProtobufUtil.toServerName(sn)); } } Collection backupMasters = null; if (proto.getBackupMastersList() != null) { backupMasters = new ArrayList(proto.getBackupMastersList().size()); for (HBaseProtos.ServerName sn : proto.getBackupMastersList()) { backupMasters.add(ProtobufUtil.toServerName(sn)); } } Map rit = null; if (proto.getRegionsInTransitionList() != null) { rit = new HashMap(proto.getRegionsInTransitionList().size()); for (RegionInTransition region : proto.getRegionsInTransitionList()) { String key = new String(region.getSpec().getValue().toByteArray()); RegionState value = RegionState.convert(region.getRegionState()); rit.put(key, value); } } String[] masterCoprocessors = null; if (proto.getMasterCoprocessorsList() != null) { final int numMasterCoprocessors = proto.getMasterCoprocessorsCount(); masterCoprocessors = new String[numMasterCoprocessors]; for (int i = 0; i < numMasterCoprocessors; i++) { masterCoprocessors[i] = proto.getMasterCoprocessors(i).getName(); } } return new ClusterStatus(proto.getHbaseVersion().getVersion(), ClusterId.convert(proto.getClusterId()).toString(),servers,deadServers, ProtobufUtil.toServerName(proto.getMaster()),backupMasters,rit,masterCoprocessors, proto.getBalancerOn()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy