This module is designed to resemble the Pigeon Java client API but with tweaks to follow the convention of Node.js modules. Develops that are familiar with the Pigeon Java client would be able to pick it up quickly.
This module has been tested to work with Pigeon version 2.3.10.
- Install node.
- Install node-pigeon-client using npm:
$ npm install node-pigeon-client --save
- An environment configuration file
/data/webapps/appenv
should be provided in the given format
deployenv = qa # Environment.
zkserver = 127.0.0.1:2181 # Zookeeper host and port.
Remote service "EchoService":
public class EchoService {
public int hello(int a) {
return a;
}
}
Call the remote service "EchoService":
var pigeon = require('node-pigeon-client');
var java = require('node-pigeon-client').java;
var url = 'EchoService'; // Remote service url.
pigeon.getService(url, function(err, service) {
if (err) {
return console.log('Get remote service error: %s.', err);
}
service.hello(java.int(123456), function(err, result) {
if (err) {
return console.log('Call remote service method error: %s.', err);
}
// Output 123456 to the console.
console.log('Remote service method result: %d.', result);
});
});
Retrieve the service of the given url.
Arguments
-
url
String
- The service url. -
options
Object
- An object to set the service retrive options. Currently available options are:zkserver
: Comma seperatedhost:port
pairs, each represents a Zookeeper server. e.g.
'127.0.0.1:2181, 127.0.0.1:2182, 127.0.0.1:2183'
timeout
Remote service method call timeout in milliseconds.protocol
Protocol of remote service method call.serialize
Serailization of network transmission.timeoutRetry
Whether to retry when timeout.retries
The number of retry attempts for timeout.loadBalance
Type of remote service server load balance.
Default options:
{ zkserver : '127.0.0.1:2181' // Can also set in '/data/webapps/appenv'. timeout : 1000, protocol : 'http' // http. serialize : 'hessian' // hessian. timeoutRetry: true // true/false retries : 1 loadBalance : 'autoaware' // autoaware/roundRobin/random }
-
callback(err, service)
Function
- The callback function. Theservice
can be regarded as an object containing all the service methods that can be called.
- null
- int
- long
- double
- boolean
- java.lang.Integer
- java.lang.Long
- java.lang.Double
- java.lang.Boolean
- java.lang.String
- java.lang.Object
- java.util.List
- java.util.Set
- java.util.Date
- array
- user-defined
Example
Object a = null;
var a = java.null()
Example
int a = 123;
var a = java.int(123);
Example
long a = 123;
var a = java.long(123);
Example
double a = 1.23;
var a = java.double(1.23);
Example
boolean a = true;
var a = java.boolean(true);
Example
java.lang.Integer a = new java.lang.Integer(123);
var a = java.Integer(123);
Example
java.lang.Long a = new java.lang.Long(123);
var a = java.Long(123);
Example
java.lang.Double a = new java.lang.Double(1.23);
var a = java.Double(1.23);
Example
java.lang.Boolean a = new java.lang.Boolean(true);
var a = java.Boolean(true);
Example
java.lang.String a = new java.lang.String('123');
var a = java.String('123');
Example
public Class Car {
private String name;
private int money;
private ArrayList<Integer> wheelSize = new ArrayList<Integer>();
public Car(name, money, wheelSize) {
this.name = name;
this.money = money;
this.wheelSize = wheelSize;
}
}
java.lang.Object a = new Car("Benz", 123, new ArrayList([1, 2, 3, 4]));
var a = java.Object({
name : java.String('Benz'),
money : java.int(123),
wheelSize: java.List.Integer([1, 2, 3, 4])
});
Generics
represents the following types:
- int
- long
- double
- boolean
- java.lang.Integer
- java.lang.Long
- java.lang.Double
- java.lang.Boolean
- java.lang.String
- java.lang.Object
- java.util.Date
- user-defined
Example
List<String> a = new ArrayList(["a", "b", "c"]);
var a = java.List.String(['a', 'b', 'c']);
See java.List.Generics(jsArray).
See java.List.Generics(jsArray).
Example
java.util.Date a = new java.util.Date();
var a = java.Date(new Date());
Example
package packagename;
public Class Car {
private String name;
private int money;
private ArrayList<Integer> wheelSize = new ArrayList<Integer>();
public Car(name, money, wheelSize) {
this.name = name;
this.money = money;
this.wheelSize = wheelSize;
}
}
packagename.Car a = new packagename.Car("Benz", 123, new ArrayList([1, 2, 3, 4]));
var a = java.Class('packagename.Car', {
name : java.String('Benz'),
money : java.int(123),
wheelSize: java.List.Integer([1, 2, 3, 4])
})