Java源码示例:org.apache.hadoop.metrics.util.MBeanUtil
示例1
/**
* Register the FSDataset MBean using the name
* "hadoop:service=DataNode,name=FSDatasetState-<storageid>"
* We use storage id for MBean name since a minicluster within a single
* Java VM may have multiple Simulated Datanodes.
*/
void registerMBean(final String storageId) {
// We wrap to bypass standard mbean naming convetion.
// This wraping can be removed in java 6 as it is more flexible in
// package naming for mbeans and their impl.
StandardMBean bean;
try {
bean = new StandardMBean(this,FSDatasetMBean.class);
mbeanName = MBeanUtil.registerMBean("DataNode",
"FSDatasetState-" + storageId, bean);
} catch (NotCompliantMBeanException e) {
e.printStackTrace();
}
DataNode.LOG.info("Registered FSDatasetStatusMBean");
}
示例2
/**
* Register the FSDataset MBean using the name
* "hadoop:service=DataNode,name=FSDatasetState-<storageid>"
*/
void registerMBean(final String storageId) {
// We wrap to bypass standard mbean naming convetion.
// This wraping can be removed in java 6 as it is more flexible in
// package naming for mbeans and their impl.
StandardMBean bean;
String storageName;
if (storageId == null || storageId.equals("")) {// Temp fix for the uninitialized storage
storageName = "UndefinedStorageId" + rand.nextInt();
} else {
storageName = storageId;
}
try {
bean = new StandardMBean(this,FSDatasetMBean.class);
mbeanName = MBeanUtil.registerMBean("DataNode", "FSDatasetState-" + storageName, bean);
versionBeanName = VersionInfo.registerJMX("DataNode");
} catch (NotCompliantMBeanException e) {
e.printStackTrace();
}
DataNode.LOG.info("Registered FSDatasetStatusMBean");
}
示例3
/**
* Register the FSDataset MBean using the name
* "hadoop:service=DataNode,name=FSDatasetState-<storageid>"
* We use storage id for MBean name since a minicluster within a single
* Java VM may have multiple Simulated Datanodes.
*/
void registerMBean(final String storageId) {
// We wrap to bypass standard mbean naming convetion.
// This wraping can be removed in java 6 as it is more flexible in
// package naming for mbeans and their impl.
StandardMBean bean;
try {
bean = new StandardMBean(this,FSDatasetMBean.class);
mbeanName = MBeanUtil.registerMBean("DataNode",
"FSDatasetState-" + storageId, bean);
} catch (NotCompliantMBeanException e) {
e.printStackTrace();
}
DataNode.LOG.info("Registered FSDatasetStatusMBean");
}
示例4
/**
* Register the FSNamesystem MBean using the name
* "hadoop:service=NameNode,name=FSNamesystemState"
*/
void registerMBean(Configuration conf) {
// We wrap to bypass standard mbean naming convention.
// This wraping can be removed in java 6 as it is more flexible in
// package naming for mbeans and their impl.
StandardMBean bean;
try {
myFSMetrics = new FSNamesystemMetrics(conf);
bean = new StandardMBean(this,FSNamesystemMBean.class);
mbeanName = MBeanUtil.registerMBean("NameNode", "FSNamesystemState", bean);
} catch (NotCompliantMBeanException e) {
e.printStackTrace();
}
LOG.info("Registered FSNamesystemStatusMBean");
}
示例5
/**
* Register the FSDataset MBean using the name
* "hadoop:service=DataNode,name=FSDatasetState-<storageid>"
*/
void registerMBean(final String storageId) {
// We wrap to bypass standard mbean naming convetion.
// This wraping can be removed in java 6 as it is more flexible in
// package naming for mbeans and their impl.
StandardMBean bean;
String storageName;
if (storageId == null || storageId.equals("")) {// Temp fix for the uninitialized storage
storageName = "UndefinedStorageId" + rand.nextInt();
} else {
storageName = storageId;
}
try {
bean = new StandardMBean(this,FSDatasetMBean.class);
mbeanName = MBeanUtil.registerMBean("DataNode", "FSDatasetState-" + storageName, bean);
} catch (NotCompliantMBeanException e) {
e.printStackTrace();
}
DataNode.LOG.info("Registered FSDatasetStatusMBean");
}
示例6
void close() throws IOException {
if (this.infoServer != null) {
LOG.info("Stopping infoServer");
try {
this.infoServer.stop();
} catch (Exception ex) {
LOG.warn("Exception shutting down JobTracker", ex);
}
}
if (this.interTrackerServer != null) {
LOG.info("Stopping interTrackerServer");
this.interTrackerServer.stop();
}
shutdown = true;
closeThread(this.expireTrackersThread);
closeThread(this.retireJobsThread);
closeThread(this.jobUpdaterThread);
if (taskScheduler != null) {
taskScheduler.terminate();
}
closeThread(this.expireLaunchingTaskThread);
closeThread(this.completedJobsStoreThread);
if (versionBeanName != null) {
MBeanUtil.unregisterMBean(versionBeanName);
}
LOG.info("stopped all jobtracker services");
return;
}
示例7
public void registerMBean() {
StandardMBean avatarNodeBean;
try {
avatarNodeBean = new StandardMBean(this, AvatarNodeStatusMBean.class);
MBeanUtil.registerMBean("AvatarNode", "AvatarNodeState", avatarNodeBean);
} catch (NotCompliantMBeanException mex) {
LOG.error("Error registering mbean with JMX", mex);
}
}
示例8
private synchronized JMXContextMBean getOrCreateMBean(String recordName) {
JMXContextMBean bean = JMXBeans.get(recordName);
if (bean == null) {
bean = new JMXContextMBean(recordName);
JMXBeans.put(recordName, bean);
if (isMonitoring()) {
ObjectName registeredName =
MBeanUtil.registerMBean(getContextName(), recordName, bean);
beanHandles.put(bean, registeredName);
}
}
return bean;
}
示例9
@Override
protected void remove(MetricsRecordImpl record) {
super.remove(record);
String recordName = record.getRecordName();
JMXContextMBean bean = JMXBeans.remove(recordName);
if (bean == null) {
return;
}
// Currently - one bean per record, so remove the bean
ObjectName name = beanHandles.remove(bean);
MBeanUtil.unregisterMBean(name);
}
示例10
@Override
public synchronized void startMonitoring() throws IOException {
for (Map.Entry<String, JMXContextMBean> beanEntry : JMXBeans.entrySet()) {
ObjectName registeredName = MBeanUtil.registerMBean(getContextName(),
beanEntry.getKey(),
beanEntry.getValue());
beanHandles.put(beanEntry.getValue(), registeredName);
}
super.startMonitoring();
}
示例11
@Override
public synchronized void stopMonitoring() {
for (ObjectName name : beanHandles.values()) {
MBeanUtil.unregisterMBean(name);
}
beanHandles.clear();
super.stopMonitoring();
}
示例12
public static ObjectName registerJMX(String daemon) {
StandardMBean versionBean;
ObjectName versionBeanName = null;
try {
versionBean = new StandardMBean(new VersionInfo(),
VersionInfoMBean.class);
versionBeanName =
MBeanUtil.registerMBean(daemon, "Version", versionBean);
} catch (NotCompliantMBeanException e) {
e.printStackTrace();
}
return versionBeanName;
}
示例13
RpcMgt(final String serviceName, final String port,
final RpcMetrics metrics, Server server) {
myMetrics = metrics;
myServer = server;
mbeanName = MBeanUtil.registerMBean(serviceName,
"RpcStatisticsForPort" + port, this);
}
示例14
/**
*
* @param mr - the metrics registry that has all the metrics
* @param serviceName - the service name for the rpc service
* @param port - the rpc port.
*/
public RpcActivityMBean(final MetricsRegistry mr, final String serviceName, final String port) {
super(mr, "Rpc layer statistics");
mbeanName = MBeanUtil.registerMBean(serviceName,
"RpcActivityForPort" + port, this);
}
示例15
public DataNodeActivityMBean(final MetricsRegistry mr, final String storageId) {
super(mr, "Activity statistics at the DataNode");
String storageName;
if (storageId.equals("")) {// Temp fix for the uninitialized storage
storageName = "UndefinedStorageId" + rand.nextInt();
} else {
storageName = storageId;
}
mbeanName = MBeanUtil.registerMBean("DataNode", "DataNodeActivity-" + storageName, this);
}
示例16
public void shutdown() {
if (mbeanName != null)
MBeanUtil.unregisterMBean(mbeanName);
if (versionBeanName != null) {
MBeanUtil.unregisterMBean(versionBeanName);
}
if (asyncDiskService != null) {
asyncDiskService.shutdown();
}
if(volumes != null) {
lock.writeLock().lock();
try {
if (volumes.scannersExecutor != null) {
volumes.scannersExecutor.shutdown();
}
for (FSVolume volume : volumes.getVolumes()) {
if(volume != null) {
volume.shutdown();
}
}
} finally {
lock.writeLock().unlock();
}
}
}
示例17
private void shutdownMXBean() {
if (datanodeMXBeanName != null) {
MBeanUtil.unregisterMBean(datanodeMXBeanName);
}
if (pulseChecker != null) {
pulseChecker.shutdown();
}
}
示例18
RpcMgt(final String serviceName, final String port,
final RpcMetrics metrics, Server server) {
myMetrics = metrics;
myServer = server;
mbeanName = MBeanUtil.registerMBean(serviceName,
"RpcStatisticsForPort" + port, this);
}
示例19
/**
*
* @param mr - the metrics registry that has all the metrics
* @param serviceName - the service name for the rpc service
* @param port - the rpc port.
*/
public RpcActivityMBean(final MetricsRegistry mr, final String serviceName, final String port) {
super(mr, "Rpc layer statistics");
mbeanName = MBeanUtil.registerMBean(serviceName,
"RpcActivityForPort" + port, this);
}
示例20
public DataNodeActivityMBean(final MetricsRegistry mr, final String storageId) {
super(mr, "Activity statistics at the DataNode");
String storageName;
if (storageId.equals("")) {// Temp fix for the uninitialized storage
storageName = "UndefinedStorageId" + rand.nextInt();
} else {
storageName = storageId;
}
mbeanName = MBeanUtil.registerMBean("DataNode", "DataNodeActivity-" + storageName, this);
}
示例21
public void shutdown() {
if (mbeanName != null)
MBeanUtil.unregisterMBean(mbeanName);
if(volumes != null) {
for (FSVolume volume : volumes.volumes) {
if(volume != null) {
volume.dfsUsage.shutdown();
}
}
}
}
示例22
public void shutdown() {
if (mbeanName != null)
MBeanUtil.unregisterMBean(mbeanName);
}
示例23
public void register(Object beanObject) {
StandardMBean bean = this.createBean(beanObject);
beanName = MBeanUtil.registerMBean(serviceName, name, bean);
}
示例24
public void unregister() {
if (serviceName != null && name != null) {
MBeanUtil.unregisterMBean(beanName);
}
}
示例25
public void shutdown() {
if (mbeanName != null)
MBeanUtil.unregisterMBean(mbeanName);
}
示例26
public void shutdown() {
if (mbeanName != null)
MBeanUtil.unregisterMBean(mbeanName);
}
示例27
protected NameNodeActivtyMBean(final MetricsRegistry mr) {
super(mr, "Activity statistics at the NameNode");
mbeanName = MBeanUtil.registerMBean("NameNode", "NameNodeActivity", this);
}
示例28
public void shutdown() {
if (mbeanName != null)
MBeanUtil.unregisterMBean(mbeanName);
}
示例29
protected HighTideNodeActivityMBean(final MetricsRegistry mr) {
super(mr, "Activity statistics at the HighTideNode");
mbeanName = MBeanUtil.registerMBean("HighTideNode", "HighTideNodeActivity", this);
}
示例30
public void shutdown() {
if (mbeanName != null)
MBeanUtil.unregisterMBean(mbeanName);
}