1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
/*
* JBoss, Home of Professional Open Source
* Copyright 2005, JBoss Inc., and individual contributors as indicated
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.remoting.samples.callback.statistics;
import java.util.HashMap;
import org.jboss.remoting.Client;
import org.jboss.remoting.InvokerLocator;
import org.jboss.remoting.callback.Callback;
import org.jboss.remoting.callback.CallbackPoller;
import org.jboss.remoting.callback.HandleCallbackException;
import org.jboss.remoting.callback.InvokerCallbackHandler;
/**
* Sample client that demonstrates CallbackPoller tuning statistics.
*
* @author <a href="mailto:ron.sigal@jboss.com">Ron Sigal</a>
* @author <a href="mailto:telrod@e2technologies.net">Tom Elrod</a>
*/
public class CallbackClient
{
// Default locator values
private static String transport = "socket";
private static String host = "localhost";
private static int port = 5400;
/**
* Registers callback listener and asks CallbackPoller to print statistics.
*/
public void getPolledCallbacks(String locatorURI) throws Throwable
{
System.out.println("Calling remoting server with locator uri of: " + locatorURI);
InvokerLocator locator = new InvokerLocator(locatorURI);
Client client = new Client(locator);
client.connect();
// Registter callback handler and tell CallbackPoller to report statistics.
CallbackHandler callbackHandler = new CallbackHandler();
HashMap metadata = new HashMap();
metadata.put(CallbackPoller.REPORT_STATISTICS, "true");
client.addListener(callbackHandler, metadata);
// Wait for callbacks to received, processed, and acknowledged.
Thread.sleep(20000);
// remove callback handler from server
client.removeListener(callbackHandler);
client.disconnect();
}
/**
* Can pass transport and port to be used as parameters.
*/
public static void main(String[] args)
{
if(args != null && args.length == 2)
{
transport = args[0];
port = Integer.parseInt(args[1]);
}
String locatorURI = transport + "://" + host + ":" + port;
CallbackClient callbackClient = new CallbackClient();
try
{
callbackClient.getPolledCallbacks(locatorURI);
}
catch(Throwable e)
{
e.printStackTrace();
}
}
/**
* Our implementation of the InvokerCallbackHandler. Simply
* prints out the callback object's message upon receiving it.
*/
public class CallbackHandler implements InvokerCallbackHandler
{
public void handleCallback(Callback callback) throws HandleCallbackException
{
// Slow down callback handling so callbacks build up in CallbackPoller.
try
{
Thread.sleep(1000);
}
catch (InterruptedException e) {}
System.out.println("Received push callback.");
System.out.println("Received callback value of: " + callback.getCallbackObject());
System.out.println("Received callback server invoker of: " + callback.getServerLocator());
}
}
}
|