001/* 002 * Licensed to the Apache Software Foundation (ASF) under one 003 * or more contributor license agreements. See the NOTICE file 004 * distributed with this work for additional information 005 * regarding copyright ownership. The ASF licenses this file 006 * to you under the Apache License, Version 2.0 (the 007 * "License"); you may not use this file except in compliance 008 * with the License. You may obtain a copy of the License at 009 * 010 * http://www.apache.org/licenses/LICENSE-2.0 011 * 012 * Unless required by applicable law or agreed to in writing, software 013 * distributed under the License is distributed on an "AS IS" BASIS, 014 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 015 * See the License for the specific language governing permissions and 016 * limitations under the License. 017 */ 018package org.apache.hadoop.hbase.master; 019 020import java.util.AbstractMap.SimpleImmutableEntry; 021import java.util.Collections; 022import java.util.HashMap; 023import java.util.Map; 024import java.util.Map.Entry; 025import org.apache.commons.lang3.StringUtils; 026import org.apache.hadoop.hbase.ServerName; 027import org.apache.hadoop.hbase.TableName; 028import org.apache.hadoop.hbase.quotas.QuotaObserverChore; 029import org.apache.hadoop.hbase.quotas.SpaceQuotaSnapshot; 030import org.apache.hadoop.hbase.zookeeper.ZKWatcher; 031import org.apache.yetus.audience.InterfaceAudience; 032 033/** 034 * Impl for exposing HMaster Information through JMX 035 */ 036@InterfaceAudience.Private 037public class MetricsMasterWrapperImpl implements MetricsMasterWrapper { 038 039 private final HMaster master; 040 041 public MetricsMasterWrapperImpl(final HMaster master) { 042 this.master = master; 043 } 044 045 @Override 046 public double getAverageLoad() { 047 return master.getAverageLoad(); 048 } 049 050 @Override 051 public long getSplitPlanCount() { 052 if (master.getRegionNormalizerManager() == null) { 053 return 0; 054 } 055 return master.getRegionNormalizerManager().getSplitPlanCount(); 056 } 057 058 @Override 059 public long getMergePlanCount() { 060 if (master.getRegionNormalizerManager() == null) { 061 return 0; 062 } 063 return master.getRegionNormalizerManager().getMergePlanCount(); 064 } 065 066 @Override 067 public long getMasterInitializationTime() { 068 return master.getMasterFinishedInitializationTime(); 069 } 070 071 @Override 072 public String getClusterId() { 073 return master.getClusterId(); 074 } 075 076 @Override 077 public String getZookeeperQuorum() { 078 ZKWatcher zk = master.getZooKeeper(); 079 if (zk == null) { 080 return ""; 081 } 082 return zk.getQuorum(); 083 } 084 085 @Override 086 public String[] getCoprocessors() { 087 return master.getMasterCoprocessors(); 088 } 089 090 @Override 091 public long getStartTime() { 092 return master.getMasterStartTime(); 093 } 094 095 @Override 096 public long getActiveTime() { 097 return master.getMasterActiveTime(); 098 } 099 100 @Override 101 public String getRegionServers() { 102 ServerManager serverManager = this.master.getServerManager(); 103 if (serverManager == null) { 104 return ""; 105 } 106 return StringUtils.join(serverManager.getOnlineServers().keySet(), ";"); 107 } 108 109 @Override 110 public int getNumRegionServers() { 111 ServerManager serverManager = this.master.getServerManager(); 112 if (serverManager == null) { 113 return 0; 114 } 115 return serverManager.getOnlineServers().size(); 116 } 117 118 @Override 119 public String getDeadRegionServers() { 120 ServerManager serverManager = this.master.getServerManager(); 121 if (serverManager == null) { 122 return ""; 123 } 124 return StringUtils.join(serverManager.getDeadServers().copyServerNames(), ";"); 125 } 126 127 @Override 128 public int getNumDeadRegionServers() { 129 ServerManager serverManager = this.master.getServerManager(); 130 if (serverManager == null) { 131 return 0; 132 } 133 return serverManager.getDeadServers().size(); 134 } 135 136 @Override 137 public boolean isRunning() { 138 return !(master.isStopped() || master.isStopping()); 139 } 140 141 @Override 142 public String getDrainingRegionServers() { 143 ServerManager serverManager = this.master.getServerManager(); 144 if (serverManager == null) { 145 return ""; 146 } 147 return StringUtils.join(serverManager.getDrainingServersList(), ";"); 148 } 149 150 @Override 151 public int getNumDrainingRegionServers() { 152 ServerManager serverManager = this.master.getServerManager(); 153 if (serverManager == null) { 154 return 0; 155 } 156 return serverManager.getDrainingServersList().size(); 157 } 158 159 @Override 160 public String getServerName() { 161 ServerName serverName = master.getServerName(); 162 if (serverName == null) { 163 return ""; 164 } 165 return serverName.getServerName(); 166 } 167 168 @Override 169 public boolean getIsActiveMaster() { 170 return master.isActiveMaster(); 171 } 172 173 @Override 174 public long getNumWALFiles() { 175 return master.getNumWALFiles(); 176 } 177 178 @Override 179 public Map<String, Entry<Long, Long>> getTableSpaceUtilization() { 180 if (master == null) { 181 return Collections.emptyMap(); 182 } 183 QuotaObserverChore quotaChore = master.getQuotaObserverChore(); 184 if (quotaChore == null) { 185 return Collections.emptyMap(); 186 } 187 Map<TableName, SpaceQuotaSnapshot> tableSnapshots = quotaChore.getTableQuotaSnapshots(); 188 Map<String, Entry<Long, Long>> convertedData = new HashMap<>(); 189 for (Entry<TableName, SpaceQuotaSnapshot> entry : tableSnapshots.entrySet()) { 190 convertedData.put(entry.getKey().toString(), convertSnapshot(entry.getValue())); 191 } 192 return convertedData; 193 } 194 195 @Override 196 public Map<String, Entry<Long, Long>> getNamespaceSpaceUtilization() { 197 QuotaObserverChore quotaChore = master.getQuotaObserverChore(); 198 if (quotaChore == null) { 199 return Collections.emptyMap(); 200 } 201 Map<String, SpaceQuotaSnapshot> namespaceSnapshots = quotaChore.getNamespaceQuotaSnapshots(); 202 Map<String, Entry<Long, Long>> convertedData = new HashMap<>(); 203 for (Entry<String, SpaceQuotaSnapshot> entry : namespaceSnapshots.entrySet()) { 204 convertedData.put(entry.getKey(), convertSnapshot(entry.getValue())); 205 } 206 return convertedData; 207 } 208 209 Entry<Long, Long> convertSnapshot(SpaceQuotaSnapshot snapshot) { 210 return new SimpleImmutableEntry<Long, Long>(snapshot.getUsage(), snapshot.getLimit()); 211 } 212}