Daniel Fuchs 6b53043eea 5072476: RFE: support cascaded (federated) MBean Servers
6299231: Add support for named MBean Servers

New javax.management.namespace package.

Reviewed-by: emcmanus
2008-09-04 14:46:36 +02:00

255 lines
8.7 KiB
Java

/*
* Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
import java.util.Random;
import java.util.Set;
import javax.management.AttributeChangeNotification;
import javax.management.ListenerNotFoundException;
import javax.management.MBeanAttributeInfo;
import javax.management.MBeanInfo;
import javax.management.MBeanNotificationInfo;
import javax.management.MBeanOperationInfo;
import javax.management.MBeanParameterInfo;
import javax.management.MBeanRegistration;
import javax.management.MBeanServer;
import javax.management.NotCompliantMBeanException;
import javax.management.NotificationBroadcasterSupport;
import javax.management.NotificationEmitter;
import javax.management.NotificationFilter;
import javax.management.NotificationListener;
import javax.management.ObjectName;
import javax.management.StandardMBean;
/**
* Dynamic MBean based on StandardMBean
* Class Wombat
* Wombat Description
* @author dfuchs
*/
public class Wombat extends StandardMBean
implements WombatMBean, NotificationEmitter, MBeanRegistration {
/**
* Attribute : Caption
*/
private String caption = "I'm a wombat";
private final long MAX_SEED = 36000;
private final long seed;
private final long period;
private volatile int mood = 0;
public int getMood() {
final long degree = seed + (System.currentTimeMillis()/period)%MAX_SEED;
final double angle = ((double)degree)/100;
mood = (int)(100.0*Math.sin(angle));
return mood;
}
public Wombat() throws NotCompliantMBeanException {
super(WombatMBean.class);
final Random r = new Random();
seed = ((r.nextLong() % MAX_SEED) + MAX_SEED)%MAX_SEED;
period = 200 + (((r.nextLong()%80)+80)%80)*10;
}
/**
* Next are the methods to compute MBeanInfo.
* You shouldn't update these methods.
*/
@Override
protected String getDescription(MBeanInfo info) {
return "Wombats are strange beasts. You will find them down under " +
"and in some computer programms.";
}
@Override
protected String getDescription(MBeanAttributeInfo info) {
String description = null;
if (info.getName().equals("Caption")) {
description = "A simple caption to describe a wombat";
}
if (info.getName().equals("Mood")) {
description = "This Wombat's mood on a [-100,+100] scale."+
" -100 means that this wombat is very angry.";
}
return description;
}
@Override
protected String getDescription(MBeanOperationInfo op,
MBeanParameterInfo param,
int sequence) {
return null;
}
@Override
protected String getParameterName(MBeanOperationInfo op,
MBeanParameterInfo param,
int sequence) {
return null;
}
@Override
protected String getDescription(MBeanOperationInfo info) {
String description = null;
return description;
}
@Override
public MBeanInfo getMBeanInfo() {
MBeanInfo mbinfo = super.getMBeanInfo();
return new MBeanInfo(mbinfo.getClassName(),
mbinfo.getDescription(),
mbinfo.getAttributes(),
mbinfo.getConstructors(),
mbinfo.getOperations(),
getNotificationInfo());
}
/**
* Get A simple caption to describe a wombat
*/
public synchronized String getCaption() {
return caption;
}
/**
* Set A simple caption to describe a wombat
*/
public void setCaption(String value) {
final String oldValue;
synchronized (this) {
oldValue = caption;
caption = value;
}
final AttributeChangeNotification notif =
new AttributeChangeNotification(objectName,
getNextSeqNumber(),
System.currentTimeMillis(),
"Caption changed","Caption",
String.class.getName(),oldValue,value);
broadcaster.sendNotification(notif);
}
/**
* MBeanNotification support
* You shouldn't update these methods
*/
public void addNotificationListener(NotificationListener listener, NotificationFilter filter, Object handback) throws IllegalArgumentException {
broadcaster.addNotificationListener(listener, filter, handback);
}
public MBeanNotificationInfo[] getNotificationInfo() {
return new MBeanNotificationInfo[] {
new MBeanNotificationInfo(new String[] {
AttributeChangeNotification.ATTRIBUTE_CHANGE},
javax.management.AttributeChangeNotification.class.getName(),
"Sent when the caption changes")
};
}
public void removeNotificationListener(NotificationListener listener) throws ListenerNotFoundException {
broadcaster.removeNotificationListener(listener);
}
public void removeNotificationListener(NotificationListener listener, NotificationFilter filter, Object handback) throws ListenerNotFoundException {
broadcaster.removeNotificationListener(listener, filter, handback);
}
private synchronized long getNextSeqNumber() {
return seqNumber++;
}
private long seqNumber;
private final NotificationBroadcasterSupport broadcaster = new NotificationBroadcasterSupport();
/**
* Allows the MBean to perform any operations it needs before being
* registered in the MBean server. If the name of the MBean is not
* specified, the MBean can provide a name for its registration. If
* any exception is raised, the MBean will not be registered in the
* MBean server.
* @param server The MBean server in which the MBean will be registered.
* @param name The object name of the MBean. This name is null if the
* name parameter to one of the createMBean or registerMBean methods in
* the MBeanServer interface is null. In that case, this method must
* return a non-null ObjectName for the new MBean.
* @return The name under which the MBean is to be registered. This value
* must not be null. If the name parameter is not null, it will usually
* but not necessarily be the returned value.
* @throws Exception This exception will be caught by the MBean server and
* re-thrown as an MBeanRegistrationException.
*/
@Override
public ObjectName preRegister(MBeanServer server, ObjectName name)
throws Exception {
objectName = name;
mbeanServer = server;
return super.preRegister(server, name);
}
/**
* Allows the MBean to perform any operations needed after having
* been registered in the MBean server or after the registration has
* failed.
* @param registrationDone Indicates wether or not the MBean has been
* successfully registered in the MBean server. The value false means
* that the registration has failed.
*/
@Override
public void postRegister(Boolean registrationDone) {
super.postRegister(registrationDone);
}
/**
* Allows the MBean to perform any operations it needs before being
* unregistered by the MBean server.
* @throws Exception This exception will be caught by the MBean server and
* re-thrown as an MBeanRegistrationException.
*/
@Override
public void preDeregister() throws Exception {
super.preDeregister();
}
/**
* Allows the MBean to perform any operations needed after having been
* unregistered in the MBean server.
*/
@Override
public void postDeregister() {
super.postDeregister();
}
public Set<ObjectName> listMatching(ObjectName pattern) {
return mbeanServer.queryNames(pattern, null);
}
private MBeanServer mbeanServer;
private ObjectName objectName;
}