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; import javax.management.MBeanServerConnection; import javax.management.Notification; import javax.management.NotificationListener; import javax.management.ObjectName; import javax.management.remote.JMXConnectionNotification; import javax.management.remote.JMXConnector; import javax.management.remote.JMXConnectorFactory; import javax.management.remote.JMXServiceURL; public class Client { public static void run(String url) throws Exception { final int notifEmittedCnt = 10; final CountDownLatch counter = new CountDownLatch(notifEmittedCnt); final Set seqSet = Collections.synchronizedSet(new HashSet()); final AtomicBoolean duplNotification = new AtomicBoolean(); JMXServiceURL serverUrl = new JMXServiceURL(url); ObjectName name = new ObjectName("test", "foo", "bar"); JMXConnector jmxConnector = JMXConnectorFactory.connect(serverUrl); System.out.println("client connected"); jmxConnector.addConnectionNotificationListener(new NotificationListener() { @Override public void handleNotification(Notification notification, Object handback) { 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