2012-12-20 20:12:32 +04:00
|
|
|
|
2013-05-28 15:57:45 +02:00
|
|
|
import java.util.Collections;
|
|
|
|
import java.util.HashSet;
|
|
|
|
import java.util.Set;
|
|
|
|
import java.util.concurrent.CountDownLatch;
|
|
|
|
import java.util.concurrent.TimeUnit;
|
|
|
|
import java.util.concurrent.atomic.AtomicBoolean;
|
2012-12-20 20:12:32 +04:00
|
|
|
import javax.management.MBeanServerConnection;
|
|
|
|
import javax.management.Notification;
|
|
|
|
import javax.management.NotificationListener;
|
|
|
|
import javax.management.ObjectName;
|
2013-05-28 15:57:45 +02:00
|
|
|
import javax.management.remote.JMXConnectionNotification;
|
2012-12-20 20:12:32 +04:00
|
|
|
import javax.management.remote.JMXConnector;
|
|
|
|
import javax.management.remote.JMXConnectorFactory;
|
|
|
|
import javax.management.remote.JMXServiceURL;
|
|
|
|
|
|
|
|
public class Client {
|
2013-05-28 15:57:45 +02:00
|
|
|
public static void run(String url) throws Exception {
|
|
|
|
final int notifEmittedCnt = 10;
|
|
|
|
final CountDownLatch counter = new CountDownLatch(notifEmittedCnt);
|
|
|
|
final Set<Long> seqSet = Collections.synchronizedSet(new HashSet<Long>());
|
|
|
|
final AtomicBoolean duplNotification = new AtomicBoolean();
|
2012-12-20 20:12:32 +04:00
|
|
|
|
2013-05-28 15:57:45 +02:00
|
|
|
JMXServiceURL serverUrl = new JMXServiceURL(url);
|
2012-12-20 20:12:32 +04:00
|
|
|
|
|
|
|
ObjectName name = new ObjectName("test", "foo", "bar");
|
|
|
|
JMXConnector jmxConnector = JMXConnectorFactory.connect(serverUrl);
|
|
|
|
System.out.println("client connected");
|
|
|
|
jmxConnector.addConnectionNotificationListener(new NotificationListener() {
|
2013-05-28 15:57:45 +02:00
|
|
|
@Override
|
2012-12-20 20:12:32 +04:00
|
|
|
public void handleNotification(Notification notification, Object handback) {
|
2013-05-28 15:57:45 +02:00
|
|
|
System.out.println("connection notification: " + notification);
|
|
|
|
if (!seqSet.add(notification.getSequenceNumber())) {
|
|
|
|
duplNotification.set(true);
|
|
|
|
}
|
|
|
|
if (notification.getType().equals(JMXConnectionNotification.NOTIFS_LOST)) {
|
|
|
|
long lostNotifs = ((Long)((JMXConnectionNotification)notification).getUserData()).longValue();
|
|
|
|
for(int i=0;i<lostNotifs;i++) {
|
|
|
|
counter.countDown();
|
|
|
|
}
|
|
|
|
}
|
2012-12-20 20:12:32 +04:00
|
|
|
}
|
|
|
|
}, null, null);
|
|
|
|
MBeanServerConnection jmxServer = jmxConnector.getMBeanServerConnection();
|
|
|
|
|
|
|
|
jmxServer.addNotificationListener(name, new NotificationListener() {
|
2013-05-28 15:57:45 +02:00
|
|
|
@Override
|
2012-12-20 20:12:32 +04:00
|
|
|
public void handleNotification(Notification notification, Object handback) {
|
2013-05-28 15:57:45 +02:00
|
|
|
System.out.println("client got: " + notification);
|
|
|
|
if (!seqSet.add(notification.getSequenceNumber())) {
|
|
|
|
duplNotification.set(true);
|
|
|
|
}
|
|
|
|
counter.countDown();
|
2012-12-20 20:12:32 +04:00
|
|
|
}
|
|
|
|
}, null, null);
|
|
|
|
|
2013-05-28 15:57:45 +02:00
|
|
|
System.out.println("client invoking foo (" + notifEmittedCnt + " times)");
|
|
|
|
for(int i=0;i<notifEmittedCnt;i++) {
|
|
|
|
System.out.print(".");
|
2012-12-20 20:12:32 +04:00
|
|
|
jmxServer.invoke(name, "foo", new Object[]{}, new String[]{});
|
|
|
|
}
|
2013-05-28 15:57:45 +02:00
|
|
|
System.out.println();
|
|
|
|
try {
|
|
|
|
System.out.println("waiting for " + notifEmittedCnt + " notifications to arrive");
|
|
|
|
if (!counter.await(30, TimeUnit.SECONDS)) {
|
|
|
|
throw new InterruptedException();
|
|
|
|
}
|
|
|
|
if (duplNotification.get()) {
|
|
|
|
System.out.println("ERROR: received duplicated notifications");
|
|
|
|
throw new Error("received duplicated notifications");
|
|
|
|
}
|
|
|
|
System.out.println("\nshutting down client");
|
|
|
|
} catch (InterruptedException e) {
|
|
|
|
System.out.println("ERROR: notification processing thread interrupted");
|
|
|
|
throw new Error("notification thread interrupted unexpectedly");
|
|
|
|
}
|
2012-12-20 20:12:32 +04:00
|
|
|
}
|
|
|
|
}
|